/* =========================================================
   Detail page styles
========================================================= */

/* =========================================================
   Ventanas individuales regeneradas de Aplicaciones
========================================================= */
.cat-item-desc-page{background:linear-gradient(180deg,#f7f9fb 0%,#fff 48%,#f2f4f6 100%);overflow-x:hidden;overflow-y:auto}

@media(max-width:1024px){}
@media(max-width:768px){}

/* =========================================================
   Llenado y dosificación: sección inferior con mini carrusel
========================================================= */

.cat-item-desc-page-overview-section {
  padding: clamp(4.5rem, 7vw, 6rem) 0 0;
  background: linear-gradient(180deg, #f7f9fb 0%, #ffffff 100%);
}

.cat-item-desc-page-overview-card {
  overflow: hidden;
  border-radius: 1.35rem;
  border: 1px solid rgba(15, 23, 42, .10);
  background: #ffffff;
  box-shadow:
    0 18px 42px rgba(0, 15, 39, .075),
    0 4px 12px rgba(0, 15, 39, .04);
}

.cat-item-desc-page-overview-header {
  padding: clamp(1.5rem, 3vw, 2.25rem);
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid rgba(15, 23, 42, .10);
  background:
    radial-gradient(circle at 85% 10%, rgba(254, 107, 0, .10), transparent 28%),
    linear-gradient(135deg, #ffffff, #f2f4f6);
}

.cat-item-desc-page-overview-header span {
  display: block;
  margin-bottom: .65rem;
  color: #a04100;
  font-family: "JetBrains Mono", monospace;
  font-size: .74rem;
  font-weight: 900;
  letter-spacing: .11em;
  text-transform: uppercase;
}

.cat-item-desc-page-overview-header h2 {
  margin: 0;
  color: #000f27;
  font-family: "Hanken Grotesk", system-ui, sans-serif;
  font-size: clamp(1.65rem, 2.0vw, 3rem) !important;
  line-height: .98;
  font-weight: 900;
  letter-spacing: -.065em;
}

.cat-item-desc-page-overview-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .9fr);
  gap: 0;
}

.cat-item-desc-page-overview-copy {
  padding: clamp(1.75rem, 4vw, 3rem);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.cat-item-desc-page-overview-copy span {
  display: block;
  margin-bottom: .75rem;
  color: #a04100;
  font-family: "JetBrains Mono", monospace;
  font-size: .74rem;
  font-weight: 900;
  letter-spacing: .11em;
  text-transform: uppercase;
}

.cat-item-desc-page-overview-copy h3 {
  margin: 0 0 1rem;
  color: #000f27;
  font-size: clamp(1.5rem, 1.35vw, 2.5rem);
  line-height: 1;
  font-weight: 900;
  letter-spacing: -.06em;
}

.cat-item-desc-page-overview-copy p {
  margin: 0;
  max-width: 720px;
  color: #44474e;
  font-size: 1.08rem;
  line-height: 1.82;
}

.cat-item-desc-page-mini-carousel {
  position: relative;
  min-height: 320px;
  overflow: hidden;
  background:
    radial-gradient(circle at 20% 20%, rgba(254, 107, 0, .18), transparent 35%),
    linear-gradient(135deg, #000f27, #0b2447);
}

.cat-item-desc-page-mini-carousel-track {
  display: flex;
  width: 300%;
  height: 100%;
  min-height: 320px;
  animation: fillingDosingMiniCarouselSlide 12s infinite;
}

.cat-item-desc-page-mini-carousel-track img {
  width: 33.333333%;
  height: auto;
  min-height: 320px;
  object-fit: cover;
  flex-shrink: 0;
}

.cat-item-desc-page-mini-carousel-dots {
  position: absolute;
  left: 50%;
  bottom: 1rem;
  transform: translateX(-50%);
  display: flex;
  gap: .5rem;
  padding: .45rem .6rem;
  border-radius: 999px;
  background: rgba(0, 15, 39, .58);
  backdrop-filter: blur(8px);
}

.cat-item-desc-page-mini-carousel-dots span {
  width: .55rem;
  height: .55rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, .45);
}

.cat-item-desc-page-mini-carousel-dots span:first-child {
  background: #ffb693;
}

.cat-item-desc-page-mini-carousel-btn {
  position: absolute;
  top: 50%;
  z-index: 20;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(15, 23, 42, .12);
  border-radius: 999px;
  background: rgba(255,255,255,.94);
  color: #000f27;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transform: translateY(-50%);
  box-shadow: 0 14px 32px rgba(0, 15, 39, .16);
  transition:
    background-color 180ms ease,
    color 180ms ease,
    border-color 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease;
}

.cat-item-desc-page-mini-carousel-prev {
  left: 14px;
}

.cat-item-desc-page-mini-carousel-next {
  right: 14px;
}

.cat-item-desc-page-mini-carousel-btn:hover:not(:disabled) {
  background: #fe6b00 !important;
  color: #ffffff !important;
  border-color: #fe6b00 !important;
  transform: translateY(-50%) scale(1.04);
  box-shadow: 0 18px 36px rgba(254, 107, 0, .28);
}

.cat-item-desc-page-mini-carousel-btn .material-symbols-outlined {
  font-family: "Material Symbols Outlined" !important;
  font-size: 24px;
  line-height: 1;
  color: currentColor;
  text-transform: none !important;
  letter-spacing: normal !important;
}

.cat-item-desc-page-overview-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  padding: clamp(1.5rem, 3vw, 2.25rem);
  padding-top: 1.0rem;
  padding-bottom: 1.0rem;
  border-top: 1px solid rgba(15, 23, 42, .10);
  background: #ffffff;
}

.cat-item-desc-page-overview-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 1rem 1.45rem;
  border-radius: .7rem;
  text-decoration: none;
  font-family: "JetBrains Mono", monospace;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.cat-item-desc-page-overview-actions .primary-action {
  background: #fe6b00;
  color: #ffffff;
  box-shadow: 0 16px 32px rgba(254, 107, 0, .24);
}

.cat-item-desc-page-overview-actions .secondary-action {
  border: 1px solid #000f27;
  color: #000f27;
}

@keyframes fillingDosingMiniCarouselSlide {
  0%, 28% { transform: translateX(0); }
  34%, 62% { transform: translateX(-33.333333%); }
  68%, 94% { transform: translateX(-66.666666%); }
  100% { transform: translateX(0); }
}

@media (max-width: 900px) {
  .cat-item-desc-page-overview-body {
    grid-template-columns: 1fr;
  }

  .cat-item-desc-page-mini-carousel,
  .cat-item-desc-page-mini-carousel-track,
  .cat-item-desc-page-mini-carousel-track img {
    min-height: 260px;
  }
}

@media (max-width: 640px) {
  .cat-item-desc-page-overview-card {
    border-radius: 1rem;
  }

  .cat-item-desc-page-overview-actions a {
    width: 100%;
  }
}

/* =========================================================
   Carrusel principal: Llenado y dosificación
========================================================= */

.cat-item-desc-carousel {
  position: relative;
  min-height: clamp(360px, 55vh, 520px);
  overflow: hidden;
  background: #000f27;
  color: #ffffff;
}

.cat-item-desc-carousel-track {
  display: flex;
  width: 300%;
  min-height: clamp(360px, 55vh, 520px);
  transition: transform 500ms ease;
  animation: mainApplicationCarousel 16s infinite;
}

.cat-item-desc-carousel.is-manual .cat-item-desc-carousel-track {
  animation: none;
}

.cat-item-desc-carousel-slide {
  position: relative;
  width: 33.333333%;
  min-height: clamp(360px, 55vh, 520px);
  flex-shrink: 0;
  overflow: hidden;
}

.cat-item-desc-carousel-slide::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(0,15,39,.96) 0%, rgba(0,15,39,.78) 42%, rgba(0,15,39,.18) 100%),
    linear-gradient(0deg, rgba(0,15,39,.40), transparent 55%);
}

.cat-item-desc-carousel-slide::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  opacity: .13;
  background-image:
    linear-gradient(rgba(255,255,255,.18) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.18) 1px, transparent 1px);
  background-size: 52px 52px;
  mask-image: linear-gradient(to right, #000, transparent 82%);
}

.cat-item-desc-carousel-slide img {
  width: 100%;
  height: 100%;
  min-height: clamp(360px, 55vh, 520px);
  object-fit: cover;
  opacity: .78;
}

.cat-item-desc-carousel-caption {
  position: absolute;
  z-index: 3;
  left: max(16px, calc((100vw - 1280px) / 2 + 64px));
  top: 50%;
  transform: translateY(-50%);
  max-width: 720px;
  padding-right: 1.5rem;
}

.cat-item-desc-carousel-caption span {
  display: block;
  margin-bottom: .85rem;
  color: #ffb693;
  font-family: "JetBrains Mono", monospace;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.cat-item-desc-carousel-caption h1 {
  margin: 0;
  max-width: 680px;
  color: #d6e3ff;
  font-size: clamp(1.65rem, 2vw, 3rem);
  line-height: 1.78;
}

.cat-item-desc-carousel-caption p {
  margin: 0;
  max-width: 680px;
  color: #d6e3ff;
  font-size: clamp(1.05rem, 1.4vw, 1.18rem);
  line-height: 1.78;
}

.cat-item-desc-carousel-arrow {
  position: absolute;
  z-index: 5;
  top: 50%;
  transform: translateY(-50%);
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 999px;
  background: rgba(0,15,39,.58);
  color: #ffffff;
  cursor: pointer;
  backdrop-filter: blur(10px);
  transition: background-color 220ms ease, transform 220ms ease;
}

.cat-item-desc-carousel-arrow:hover {
  background: rgba(254,107,0,.82);
  transform: translateY(-50%) scale(1.05);
}

.cat-item-desc-carousel-arrow .material-symbols-outlined {
  font-family: "Material Symbols Outlined" !important;
  font-size: 2rem;
  text-transform: none !important;
  letter-spacing: normal !important;
}

.cat-item-desc-carousel-arrow-left {
  left: clamp(1rem, 3vw, 2rem);
}

.cat-item-desc-carousel-arrow-right {
  right: clamp(1rem, 3vw, 2rem);
}

.cat-item-desc-carousel-indicators {
  position: absolute;
  z-index: 5;
  left: 50%;
  bottom: 1.5rem;
  transform: translateX(-50%);
  display: flex;
  gap: .55rem;
  padding: .55rem .75rem;
  border-radius: 999px;
  background: rgba(0,15,39,.58);
  backdrop-filter: blur(10px);
}

.cat-item-desc-carousel-indicators span {
  width: .6rem;
  height: .6rem;
  border-radius: 999px;
  background: rgba(255,255,255,.45);
}

.cat-item-desc-carousel-indicators span:first-child {
  background: #ffb693;
}

@keyframes mainApplicationCarousel {
  0%, 27% { transform: translateX(0); }
  33%, 60% { transform: translateX(-33.333333%); }
  66%, 93% { transform: translateX(-66.666666%); }
  100% { transform: translateX(0); }
}

@media (max-width: 768px) {
  .cat-item-desc-carousel,
  .cat-item-desc-carousel-track,
  .cat-item-desc-carousel-slide,
  .cat-item-desc-carousel-slide img {
    min-height: 420px;
  }

  .cat-item-desc-carousel-caption {
    left: 1.25rem;
    right: 1.25rem;
    max-width: none;
  }

  .cat-item-desc-carousel-caption h1,
  .cat-item-desc-carousel-arrow {
    width: 46px;
    height: 46px;
  }

  .cat-item-desc-carousel-arrow-left {
    left: .75rem;
  }

  .cat-item-desc-carousel-arrow-right {
    right: .75rem;
  }
}

/* =========================================================
   Override altura carrusel principal
========================================================= */

.cat-item-desc-carousel,
.cat-item-desc-carousel-track,
.cat-item-desc-carousel-slide,
.cat-item-desc-carousel-slide img {
  min-height: clamp(520px, 78vh, 760px) !important;
  max-height: 760px !important;
}

@media (max-width: 768px) {
  .cat-item-desc-carousel,
  .cat-item-desc-carousel-track,
  .cat-item-desc-carousel-slide,
  .cat-item-desc-carousel-slide img {
    min-height: 560px !important;
    max-height: 560px !important;
  }
}

/* =========================================================
   Ajuste altura sección siguiente al carrusel
========================================================= */

.cat-item-desc-page-overview-section .cat-item-desc-page-overview-card {
  min-height: 125% !important;
}

.cat-item-desc-page-overview-body {
  min-height: 440px !important;
}

.cat-item-desc-page-overview-copy{
  min-height: 440px !important;
}

@media (max-width: 900px) {
  .cat-item-desc-page-overview-body,
  .cat-item-desc-page-overview-copy,
  .cat-item-desc-page-mini-carousel {
    min-height: 380px !important;
  }
}

/* =========================================================
   Formulario de contacto - Llenado y dosificación
========================================================= */

.application-contact-section {
  padding: clamp(4.5rem, 7vw, 6rem) 0;
  background:
    radial-gradient(circle at top left, rgba(254,107,0,.12), transparent 30%),
    linear-gradient(135deg,#091a33,#102b52);
  position: relative;
  overflow: hidden;
}

.application-contact-layout {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(380px, .95fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: start;
}

.application-contact-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-top: .5rem;
}

.application-contact-copy > span,
.application-contact-form-header span {
  display: block;
  margin-bottom: .8rem;
  color: #a04100;
  font-family: "JetBrains Mono", monospace;
  font-size: .74rem;
  font-weight: 900;
  letter-spacing: .11em;
  text-transform: uppercase;
}

.application-contact-copy h2,
.application-contact-form-header h2 {
  font-size: 1.5rem;
  margin-top: 0.75rem;
  margin-bottom: 0.75rem;
}

.application-contact-copy > p {
  margin: 0;
  max-width: 700px;
  color: #44474e;
  font-size: 1.08rem;
  line-height: 1.82;
}

.application-contact-points {
  display: grid;
  gap: 1rem;
  margin-top: 2rem;
}

.application-contact-points article {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem 1.15rem;
  border-radius: 1rem;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.78);
}

.application-contact-points .material-symbols-outlined {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: .9rem;
  background: #0b2447;
  color: #ffb693;
  font-size: 1.8rem;
  font-variation-settings: "FILL" 1;
}

.application-contact-points strong {
  display: block;
  margin-bottom: .35rem;
  color: #000f27;
  font-size: 1rem;
  font-weight: 800;
}

.application-contact-points p {
  margin: 0;
  color: #5a5f67;
  line-height: 1.6;
}

.application-contact-form-card {
  overflow: hidden;
  border-radius: 1.35rem;
  border: 1px solid rgba(15,23,42,.10);
  background: #ffffff;
  box-shadow:
    0 18px 42px rgba(0,15,39,.075),
    0 4px 12px rgba(0,15,39,.04);
}

.application-contact-form-header {
  margin-bottom: 0;
  padding: 1.0rem 1.0rem 1.0rem;
  border-bottom: 1px solid rgba(15,23,42,.08);
  background:
    radial-gradient(circle at 85% 10%, rgba(254,107,0,.10), transparent 28%),
    linear-gradient(135deg, #ffffff, #f2f4f6);
}

.application-contact-form {
  padding: 1.75rem;
}

.application-form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}

.application-form-field {
  display: flex;
  flex-direction: column;
  margin-bottom: 1rem;
}

.application-form-field label {
  margin-bottom: .55rem;
  color: #000f27;
  font-size: .88rem;
  font-weight: 700;
}

.application-form-field input,
.application-form-field textarea {
  width: 100%;
  border: 1px solid rgba(15,23,42,.12);
  border-radius: .85rem;
  background: #f8fafc;
  padding: .95rem 1rem;
  color: #000f27;
  font-size: .98rem;
  line-height: 1.5;
  transition: border-color 220ms ease, box-shadow 220ms ease;
}

.application-form-field input:focus,
.application-form-field textarea:focus {
  outline: none;
  border-color: #fe6b00;
  box-shadow: 0 0 0 4px rgba(254,107,0,.12);
}

.application-contact-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: .5rem;
}

.application-contact-actions button,
.application-contact-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 1rem 1.45rem;
  border-radius: .7rem;
  text-decoration: none;
  font-family: "JetBrains Mono", monospace;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.application-contact-actions button {
  border: none;
  cursor: pointer;
  background: #fe6b00;
  color: #ffffff;
  box-shadow: 0 16px 32px rgba(254,107,0,.24);
}

.application-contact-actions a {
  border: 1px solid #000f27;
  color: #000f27;
  background: transparent;
}

@media (max-width: 1024px) {
  .application-contact-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .application-form-grid {
    grid-template-columns: 1fr;
  }

  .application-contact-form-card {
    border-radius: 1rem;
  }

  .application-contact-actions button,
  .application-contact-actions a {
    width: 100%;
  }
}

/* =========================================================
   Contraste fondo oscuro formulario
========================================================= */

.application-contact-section .application-contact-copy > span,
.application-contact-section .application-contact-form-header span {
  color: #ffb693 !important;
}

.application-contact-section .application-contact-copy h2,
.application-contact-section .application-contact-form-header h3,
.application-contact-section .application-contact-points strong {
  color: #ffffff !important;
}

.application-contact-section .application-contact-copy > p,
.application-contact-section .application-contact-points p {
  color: #d6e3ff !important;
}

.application-contact-section .application-contact-points article {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  backdrop-filter: blur(10px);
}

.application-contact-section .application-contact-form-card {
  border: 1px solid rgba(255,255,255,.10) !important;
  box-shadow:
    0 22px 50px rgba(0,0,0,.28),
    0 8px 18px rgba(0,0,0,.18) !important;
}

.cat-item-desc-header {
  max-width: 780px;
  margin-bottom: 2rem;
}

.cat-item-desc-header span {
  display: block;
  margin-bottom: .75rem;
  color: #a04100;
  font-family: "JetBrains Mono", monospace;
  font-size: .74rem;
  font-weight: 900;
  letter-spacing: .11em;
  text-transform: uppercase;
}

.cat-item-desc-header p {
  margin: 0;
  color: #44474e;
  font-size: 1.08rem;
  line-height: 1.8;
}

.cat-item-desc-card {
  position: relative;
  flex: 0 0 calc((100% - 2.5rem) / 3);
  overflow: hidden;
  border-radius: 1.15rem;
  border: 1px solid rgba(15,23,42,.10);
  background:
    linear-gradient(180deg, #ffffff 0%, #f8fafc 100%) !important;
  box-shadow:
    0 16px 38px rgba(0,15,39,.07),
    0 4px 12px rgba(0,15,39,.04);
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.cat-item-desc-card:hover {
  transform: translateY(-4px);
  border-color: rgba(254,107,0,.32);
  box-shadow:
    0 24px 52px rgba(0,15,39,.12),
    0 8px 18px rgba(0,15,39,.05);
}

.cat-item-desc-card > a {
  position: absolute;
  inset: 0;
  z-index: 5;
}

.cat-item-desc-card img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  background: #0b2447;
}

.cat-item-desc-card div {
  padding: 1.35rem;
}

.cat-item-desc-card span {
  display: block;
  margin-bottom: .55rem;
  color: #a04100;
  font-family: "JetBrains Mono", monospace;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.cat-item-desc-card p {
  margin: 0;
  color: #44474e;
  line-height: 1.65;
}

@media (max-width: 1024px) {
  .cat-item-desc-card {
    flex-basis: calc((100% - 1.25rem) / 2);
  }
}

@media (max-width: 768px) {

  .cat-item-desc-card {
    flex-basis: 82%;
  }

  .cat-item-desc-card img {
    height: 180px;
  }
}

/* Carrusel principal: oscuro industrial */
.cat-item-desc-carousel {
  background:
    radial-gradient(circle at 18% 20%, rgba(254,107,0,.18), transparent 32%),
    linear-gradient(135deg, #000f27 0%, #071a35 48%, #0b2447 100%) !important;
}

/* Formulario: oscuro premium */
.application-contact-section {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgba(254,107,0,.16), transparent 30%),
    radial-gradient(circle at 85% 80%, rgba(177,199,243,.10), transparent 34%),
    linear-gradient(135deg, #061225 0%, #091a33 46%, #102b52 100%) !important;
  border-top: 1px solid rgba(255,255,255,.10);
}

.application-contact-section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .08;
  background-image:
    linear-gradient(rgba(255,255,255,.38) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.38) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.85), transparent 92%);
}

.application-contact-section > .max-w-container-max {
  position: relative;
  z-index: 1;
}

.application-contact-form-card {
  background: rgba(255,255,255,.98) !important;
}

.application-contact-points article {
  background: rgba(255,255,255,.075) !important;
  border-color: rgba(255,255,255,.12) !important;
}

/* HERO / carrusel principal: oscuro profundo */
.cat-item-desc-carousel {
  background:
    radial-gradient(circle at 15% 20%, rgba(254,107,0,.20), transparent 32%),
    radial-gradient(circle at 85% 75%, rgba(177,199,243,.08), transparent 34%),
    linear-gradient(135deg, #000814 0%, #000f27 48%, #0b2447 100%) !important;
  border-bottom: 1px solid rgba(255,255,255,.10);
}

/* FORMULARIO: oscuro más profundo y contrastado */
.application-contact-section {
  position: relative;
  overflow: hidden;
  padding-top: clamp(5.5rem, 8vw, 7rem) !important;
  padding-bottom: clamp(5.5rem, 8vw, 7rem) !important;
  background:
    radial-gradient(circle at 10% 15%, rgba(254,107,0,.22), transparent 30%),
    radial-gradient(circle at 88% 78%, rgba(177,199,243,.12), transparent 36%),
    linear-gradient(135deg, #020812 0%, #061225 42%, #0b2447 100%) !important;
  border-top: 1px solid rgba(255,255,255,.12) !important;
}

.application-contact-section::before {
  opacity: .10 !important;
  background-size: 58px 58px !important;
}

.application-contact-section::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), transparent 22%),
    linear-gradient(0deg, rgba(0,0,0,.22), transparent 40%);
}

.application-contact-section > .max-w-container-max {
  position: relative;
  z-index: 2;
}

.application-contact-form-card {
  background: rgba(255,255,255,.99) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  box-shadow:
    0 34px 84px rgba(0,0,0,.34),
    0 10px 28px rgba(0,0,0,.20) !important;
}

.application-contact-points article {
  background: rgba(255,255,255,.085) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}

/* Carrusel de aplicaciones relacionadas */
.cat-item-desc-header p {
  font-size: 1rem !important;
  line-height: 1.72 !important;
}

.cat-item-desc-card p {
  font-size: .95rem !important;
  line-height: 1.6 !important;
}

.cat-item-desc-card span {
  font-size: .63rem !important;
}

/* Formulario */

.application-contact-copy > p {
  font-size: 1rem !important;
  line-height: 1.72 !important;
}

.application-contact-points strong {
  font-size: .95rem !important;
}

.application-contact-points p {
  font-size: .92rem !important;
}

/* Etiquetas */
.cat-item-desc-header span {
  font-size: .7rem !important;
  letter-spacing: .105em !important;
}

/* Texto descriptivo uniforme */
.cat-item-desc-carousel-caption p,
.cat-item-desc-header p,
.cat-item-desc-card p,
.application-contact-copy > p,
.application-contact-points p {
  font-size: .98rem !important;
  line-height: 1.72 !important;
}

/* Labels pequeñas */
.cat-item-desc-carousel-caption span,
.cat-item-desc-header span,
.cat-item-desc-card span {
  font-size: .68rem !important;
  letter-spacing: .11em !important;
  font-weight: 900 !important;
}


/* Responsive */
@media (max-width: 768px) {
}.cat-item-desc-header {
position: relative;
  z-index: 2;
}

.cat-item-desc-header {
  padding:
    clamp(2rem, 4vw, 3rem)
    clamp(2rem, 4vw, 3rem)
    1.25rem;
}

@media (max-width: 768px) {

  .cat-item-desc-header {
    padding:
      1.5rem
      1.25rem
      1rem;
  }
}

@media (max-width: 768px) {
}.application-contact-section {
padding-top: clamp(3rem, 5vw, 4rem) !important;
  padding-bottom: clamp(3rem, 5vw, 4rem) !important;
}

/* Reducir separación interna formulario */
.application-contact-form {
  padding: 1.5rem !important;
}

.application-contact-points {
  margin-top: 1.5rem !important;
}

@media (max-width: 768px) {.application-contact-section {
padding-top: 2.5rem !important;
    padding-bottom: 2.5rem !important;
}
}
.application-contact-section {
padding-top: 2.75rem !important;
}

.application-contact-form {
  padding-top: 1rem !important;
}

.application-contact-points {
  margin-top: 1rem !important;
}

/* Mobile */
@media (max-width: 768px) {
  .application-contact-section {
  padding-top: 2rem !important;
  }
.application-contact-form-header,
.application-contact-form {
padding-top: .85rem !important;
}
}

/* Carrusel principal */
.cat-item-desc-carousel,
.cat-item-desc-carousel-slide,
.main-carousel-image-wrapper {
  min-height: 80vh !important;
  height: 80vh !important;
  max-height: 80vh !important;
}

/* Ajustar contenido interno del carrusel */
.cat-item-desc-carousel-caption {
  padding-top: 2rem !important;
  padding-bottom: 2rem !important;
}

/* Compactar cards */
.cat-item-desc-card img {
  height: 180px !important;
}

.cat-item-desc-card div {
  padding: 1rem !important;
}

/* Mobile */
@media (max-width: 768px) {

  .cat-item-desc-carousel,
  .cat-item-desc-carousel-slide,
  .main-carousel-image-wrapper {
    min-height: 65vh !important;
    height: 65vh !important;
    max-height: 65vh !important;
  }

  .cat-item-desc-card img {
    height: 150px !important;
  }
}

/* Compactar la sección del formulario/llenado */
.application-contact-section {
  padding-top: 2rem !important;
  padding-bottom: 2rem !important;
}

/* Reducir altura interna del bloque */
.application-contact-layout {
  gap: 1.5rem !important;
}

.application-contact-copy {
  padding-top: 0 !important;
}

.application-contact-copy > p {
  margin-bottom: 0 !important;
}

.application-contact-points {
  margin-top: .85rem !important;
  gap: .75rem !important;
}

.application-contact-points article {
  padding: .8rem 1rem !important;
}

.application-contact-form {
  padding: 1rem 1.25rem !important;
}

.application-form-field {
  margin-bottom: .75rem !important;
}

.application-contact-actions {
  margin-top: .25rem !important;
}

/* Mobile */
@media (max-width: 768px) {
  .application-contact-section {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }

  .application-contact-form {
    padding: .9rem 1rem !important;
  }
}

/* =========================================================
   Sección 3 rehecha
========================================================= */

.cat-item-desc-page-related-cat-section {
  padding: 2rem 0 !important;
  background: linear-gradient(180deg, #ffffff, #f7f9fb);
}

.cat-item-desc-page-related-cat-header {
  margin-bottom: 1.25rem;
}

.cat-item-desc-page-related-cat-header span {
  display: block;
  margin-bottom: .5rem;
  color: #a04100;
}

.cat-item-desc-page-related-cat-header p {
  max-width: 720px;
  margin: 0;
}

.cat-item-desc-page-related-cat-carousel {
  display: grid;
  grid-template-columns: 56px minmax(0,1fr) 56px;
  gap: 1rem;
  align-items: center;
}

.cat-item-desc-card {
  overflow: hidden;
  border-radius: 1rem;
  background: #ffffff;
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 10px 28px rgba(0,15,39,.06);
}

.cat-item-desc-card img {
  width: 100%;
  height: 180px !important;
  object-fit: cover;
}

.cat-item-desc-card div {
  padding: 1rem;
}

.cat-item-desc-card p {
  margin: 0;
}

@media (max-width: 768px) {

  .cat-item-desc-page-related-cat-section {
    padding: 1.25rem 0 !important;
  }

  .cat-item-desc-page-related-cat-carousel {
    grid-template-columns: 1fr;
  }
}

/* =========================================================
   Ajuste altura media - Sección 3
========================================================= */

.cat-item-desc-page-related-cat-section {
  padding-top: 2.75rem !important;
  padding-bottom: 2.75rem !important;
}

.cat-item-desc-page-related-cat-header {
  margin-bottom: 1.75rem !important;
}

.cat-item-desc-page-related-cat-carousel {
  gap: 1.25rem !important;
}

.cat-item-desc-card img {
  height: 220px !important;
}

.cat-item-desc-card div {
  padding: 1.25rem !important;
}

@media (max-width: 768px) {
  .cat-item-desc-page-related-cat-section {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }

  .cat-item-desc-card img {
    height: 190px !important;
  }
}

/* =========================================================
   Sección 3 con mismo contenedor visual que sección 2
========================================================= */

.cat-item-desc-overview-section {
  padding: 2rem 0 !important;
  background:
    radial-gradient(circle at 90% 12%, rgba(254,107,0,.08), transparent 26%),
    linear-gradient(180deg, #ffffff 0%, #f7f9fb 100%) !important;
}

.cat-item-desc-overview-card {
  overflow: hidden;
  border-radius: 1.35rem;
  border: 1px solid rgba(15, 23, 42, .10);
  background: #ffffff;
  box-shadow:
    0 18px 42px rgba(0, 15, 39, .075),
    0 4px 12px rgba(0, 15, 39, .04);
}

.cat-item-desc-overview-header {
  padding: 1.1rem clamp(1.5rem, 3vw, 2rem) .9rem;
  border-bottom: 1px solid rgba(15, 23, 42, .10);
  background:
    radial-gradient(circle at 85% 10%, rgba(254, 107, 0, .10), transparent 28%),
    linear-gradient(135deg, #ffffff, #f2f4f6);
}

.cat-item-desc-overview-header span {
  display: block;
  margin-bottom: .5rem;
  color: #a04100;
  font-family: "JetBrains Mono", monospace;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .105em;
  text-transform: uppercase;
}

.cat-item-desc-overview-header h2 {
  margin: 0 0 .55rem !important;
}

.cat-item-desc-overview-header p {
  max-width: 760px;
  margin: 0;
  color: #44474e;
}

.cat-item-desc-overview-body {
  padding: 1rem clamp(1.5rem, 3vw, 2rem) 1.25rem;
}

.cat-item-desc-overview-body .cat-item-desc-page-related-cat-carousel {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr) 56px;
  gap: 1rem;
  align-items: center;
}

.cat-item-desc-overview-body .cat-item-desc-card {
  overflow: hidden;
  border-radius: 1rem;
  background: #ffffff;
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 10px 28px rgba(0,15,39,.06);
}

.cat-item-desc-overview-body .cat-item-desc-card img {
  width: 100%;
  height: 220px !important;
  object-fit: cover;
}

.cat-item-desc-overview-body .cat-item-desc-card div {
  padding: 1.25rem !important;
}

.cat-item-desc-overview-body .cat-item-desc-card p {
  margin: 0;
}

@media (max-width: 768px) {
  .cat-item-desc-overview-section {
    padding: 1.25rem 0 !important;
  }

  .cat-item-desc-overview-card {
    border-radius: 1rem;
  }

  .cat-item-desc-overview-header,
  .cat-item-desc-overview-body {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .cat-item-desc-overview-body .cat-item-desc-page-related-cat-carousel {
    grid-template-columns: 1fr;
  }

  .cat-item-desc-overview-body .cat-item-desc-card img {
    height: 190px !important;
  }
}

/* =========================================================
   CAT ITEM DESC CARDS CAROUSEL
========================================================= */

.cat-item-desc-s3-cards-carousel{
  position:relative;
  width:100%;
  margin-top:2rem;
}

.cat-item-desc-s3-cards-viewport{
  overflow:hidden;
  width:100%;
}

.cat-item-desc-s3-cards-track{
  display:flex;
  gap:1.5rem;
  transition:transform .45s ease;
  will-change:transform;
}

.cat-item-desc-card{
  flex:0 0 calc(33.333% - 1rem);
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:1.25rem;
  overflow:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,.06);
}

.cat-item-desc-card img{
  width:100%;
  height:220px;
  object-fit:cover;
  display:block;
}

.cat-item-desc-card-content{
  padding:1.25rem;
}

.cat-item-desc-card h3{
  font-size:1.20rem;
  font-weight:700;
  margin-bottom:.75rem;
}

.cat-item-desc-card p{
  font-size:.95rem;
  line-height:1.6;
  color:#4b5563;
}

.cat-item-desc-s3-cards-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:44px;
  height:44px;
  border:none;
  border-radius:999px;
  background:#111827;
  color:#fff;
  cursor:pointer;
  z-index:5;
  display:flex;
  align-items:center;
  justify-content:center;

  transition:
    background-color 180ms ease,
    color 180ms ease,
    border-color 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease;
}

.cat-item-desc-s3-cards-prev{
  left:-20px;
}

.cat-item-desc-s3-cards-next{
  right:-20px;
}

.cat-item-desc-s3-cards-arrow:disabled{
  opacity:.4;
  cursor:not-allowed;
}

.cat-item-desc-s3-cards-arrow:hover:not(:disabled) {
  background: #fe6b00 !important;
  color: #ffffff !important;
  border-color: #fe6b00 !important;
  transform: translateY(-50%) scale(1.04);
  box-shadow: 0 18px 36px rgba(254, 107, 0, .28);
}

.cat-item-desc-s3-cards-arrow:hover:not(:disabled) .material-symbols-outlined {
  color: #ffffff !important;
}

@media (max-width:1024px){
  .cat-item-desc-card{
    flex:0 0 calc(50% - .75rem);
  }
}

@media (max-width:768px){
  .cat-item-desc-card{
    flex:0 0 100%;
  }

  .cat-item-desc-s3-cards-prev{
    left:0;
  }

  .cat-item-desc-s3-cards-next{
    right:0;
  }
}

/* =========================================================
   Reduce spacing between Hero and Overview
========================================================= */

.cat-item-desc-carousel{
  padding-bottom:2rem !important;
  margin-bottom:0 !important;
}

.cat-item-desc-page-overview-section{
  margin-top:1rem !important;
  padding-top:2rem !important;
}

@media (max-width:768px){
  .cat-item-desc-carousel{
    padding-bottom:1rem !important;
  }

  .cat-item-desc-page-overview-section{
    margin-top:.5rem !important;
    padding-top:1.25rem !important;
  }
}

/* =========================================================
   Cat item description - extra content sections
========================================================= */

.cat-item-desc-extra-section{padding:2.75rem 0;background:linear-gradient(180deg,#fff 0%,#f7f9fb 100%)}
.cat-item-desc-extra-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);gap:1.25rem;align-items:stretch}
.cat-item-desc-extra-panel,.cat-item-desc-process-panel{border:1px solid rgba(15,23,42,.10);border-radius:1.25rem;background:#fff;box-shadow:0 16px 40px rgba(0,15,39,.07),0 4px 12px rgba(0,15,39,.04);padding:clamp(1.5rem,3vw,2.25rem)}
.cat-item-desc-extra-panel>span,.cat-item-desc-process-panel>span{display:block;margin-bottom:.75rem;color:#a04100;font-family:"JetBrains Mono",monospace;font-size:.72rem;font-weight:900;letter-spacing:.1em;text-transform:uppercase}
.cat-item-desc-extra-panel h2,
.cat-item-desc-process-panel h2{
  margin:0 0 1rem;
  color:#000f27;
  font-size:clamp(1.5rem,1.8vw,2.25rem);
  line-height:1.08;
  font-weight:900;
  letter-spacing:-.05em
}
.cat-item-desc-extra-panel p,.cat-item-desc-process-panel p{color:#44474e;font-size:.98rem;line-height:1.72}
.cat-item-desc-extra-panel ul{margin:1.25rem 0 0;padding-left:1.15rem;color:#44474e;line-height:1.7}
.cat-item-desc-extra-panel li+li{margin-top:.65rem}
.cat-item-desc-extra-panel li::marker{color:#fe6b00}
.cat-item-desc-extra-panel-dark{background:radial-gradient(circle at 15% 15%,rgba(254,107,0,.18),transparent 30%),linear-gradient(135deg,#000f27,#0b2447);color:#fff}
.cat-item-desc-extra-panel-dark h2,.cat-item-desc-extra-panel-dark p{color:#fff}
.cat-item-desc-benefits-list{display:grid;gap:.85rem;margin-top:1.25rem}
.cat-item-desc-benefits-list article{display:flex;gap:.75rem;align-items:flex-start;padding:.9rem;border-radius:.9rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.10)}
.cat-item-desc-benefits-list .material-symbols-outlined{color:#ffb693;font-size:1.25rem;flex:0 0 auto;font-family:"Material Symbols Outlined"!important;text-transform:none!important;letter-spacing:normal!important}
.cat-item-desc-benefits-list p{margin:0;color:#d6e3ff}
.cat-item-desc-process-panel{margin-top:1.25rem}
.cat-item-desc-process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:.9rem;margin-top:1.25rem}
.cat-item-desc-process-steps article{padding:1rem;border-radius:1rem;background:#f7f9fb;border:1px solid rgba(15,23,42,.08)}
.cat-item-desc-process-steps b{display:block;margin-bottom:.65rem;color:#fe6b00;font-family:"JetBrains Mono",monospace;font-size:.8rem}
.cat-item-desc-process-steps strong{display:block;color:#000f27;font-size:1rem;font-weight:900;margin-bottom:.45rem}
.cat-item-desc-process-steps p{margin:0;font-size:.9rem;line-height:1.6}
@media (max-width:900px){.cat-item-desc-extra-grid,.cat-item-desc-process-steps{grid-template-columns:1fr}}




/* =========================================================
   Product detail hero arrows fix
========================================================= */

.cat-item-desc-s3-cards-arrow .material-symbols-outlined,
.cat-item-desc-carousel-arrow .material-symbols-outlined {
  font-family: "Material Symbols Outlined" !important;
  font-size: 26px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-transform: none !important;
  letter-spacing: normal !important;
}
