/* Main - Base */
main {
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 30px;
  box-sizing: border-box;
}

@media (max-width: 768px) {
  
  main {
    gap: 0px;
  }

  main > section#breadcrumb { 
    padding: 0px 0px!important;
  }
  .detalles-soluciones tbody tr td {
    padding: 6px 2px;
  }
  #modalSolucionDetalle table.detalles-soluciones td { 
    padding: 6px 2px!important;
  }
}

/* Breadcrumb section - Full width and horizontal layout */
main > section#breadcrumb {
  width: 100% !important;
  flex: 0 0 auto !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  order: -1;
}

main > section#breadcrumb .container {
  max-width: 100%;
}

main > section#breadcrumb .row {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

main > section#breadcrumb .col-auto {
  flex: 0 0 auto !important;
}

/* Main - Mobile: margin izquierdo y derecho de 20px */
@media (max-width: 768px) {
  main {
      margin-left: 20px !important;
      margin-right: 20px !important;
      margin-top: 0;
      margin-bottom: 0;
      width: calc(100% - 40px) !important;
      max-width: calc(100% - 40px) !important;
      box-sizing: border-box;
  }
}

/* Main - Solo desktop */
@media (min-width: 769px) {
  main {
      margin: 2% 20%;
      width: auto;
      max-width: none;
  }
}

section#soluciones-single {
  width: 100% !important;
  flex: 0 0 100% !important;
  margin: 0 auto;
  order: 0;
}

section#form-contacto {
  flex: 1;
}
.documentos-solucion {
  margin-bottom: 100px;
}

table.detalles-soluciones {
  width: 100%;
  border-collapse: collapse;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  font-family: "Segoe UI", sans-serif;
}

table.detalles-soluciones thead {
  background-color: #022B81;
  color: #fff;
}

table.detalles-soluciones th,
table.detalles-soluciones td {
  padding: 14px 16px;
  font-size: 14px;
  text-align: left;
}

table.detalles-soluciones th {
  font-weight: 600;
}

table.detalles-soluciones tbody tr:nth-child(even) {
  background-color: #F5F7FA;
}

table.detalles-soluciones tbody tr:nth-child(odd) {
  background-color: #ffffff;
}

table.detalles-soluciones tbody tr:hover {
  background-color: #E6EEFF;
  transition: background-color 0.2s ease-in-out;
}

table.detalles-soluciones td {
  color: #333;
}

.tag-solucion span {
  background-color: #E6EEFF;
  padding: 2px 10px;
  border-radius: 10px;
  font-size: 13px;
}

.info-solucion h1.title-solucion {
  color: #022b81;
  font-size: 20px;
  font-weight: 400;
  margin: 0;
  line-height: 1.3;
}

.info-solucion h1.title-solucion a {
  color: #022b81;
  text-decoration: none;
}

.info-solucion h1.title-solucion a:hover {
  text-decoration: underline;
}

.info-solucion h4.codigo-solucion {
  font-size: 20px;
  font-weight: 400;
  background: linear-gradient(90deg, #20419b 0%, #3380eb 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: inline-block;
  margin: 0;
}

@media (min-width: 768px) {
  .info-solucion h4.codigo-solucion {
      font-size: 27px;
  }
  
  .info-solucion h1.title-solucion {
      font-size: 20px;
  }
}

.info-solucion h4.seco-exterior-solucion {
  color: #022b81;
  font-size: 20px;
  font-weight: 400;
  margin: 0;
}

@media (min-width: 768px) {
  .info-solucion h4.seco-exterior-solucion {
      font-size: 15px;
  }
}

.description-solucion p {
  text-align: justify;
}

section#soluciones-single h2 {
  font-weight: 600;
  background: none;
-webkit-background-clip: border-box;
background-clip: border-box;
-webkit-text-fill-color: initial;
color: #000;
}

svg {
  height: 25px;
  width: 25px;
}

a.link-documento {
  color: #000;
}

tr:hover a.link-documento {
  color: #022b81;
}

a.link-producto:hover {
  color: #337ee9;
}

/* ============================================
 ESTILOS ESPECÃFICOS DE CONTENT-SOLUCIONES-SINGLE.PHP
 Estos estilos tienen prioridad sobre los anteriores
 ============================================ */

/* CÃ­rculo en primera columna de tabla */
.detalles-soluciones tbody td:first-child {
  color: #022B81;
  position: relative; /* Crea el marco de referencia para el cÃ­rculo */
}

.detalles-soluciones tbody td:first-child::before {
  content: "";
  position: absolute;
  /* Centrado absoluto */
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  
  /* El cÃ­rculo */
  width: 25px; 
  height: 25px;
  border: 1px solid #022B81;
  border-radius: 50%;
  pointer-events: none; /* Evita que interfiera con clics */
}

/* Layout Principal: Dos Columnas */
.solucion-main-layout {
display: flex;
flex-direction: row;
gap: 30px;
margin: 30px 0 50px 0;
align-items: flex-start;
}

/* Asegurar que el primer atributo (fuego) estÃ© alineado al top */
#soluciones-single .atributos .group-atributo:first-child {
margin-top: 0;
padding-top: 0;
}

.solucion-atributos-col {
flex: 0 0 40%;
max-width: 40%;
display: flex;
flex-direction: column;
align-self: flex-start;
}

.solucion-imagenes-col {
flex: 0 0 60%;
max-width: 60%;
display: flex;
flex-direction: column;
align-items: center;
align-self: flex-start;
margin-top: 0;
}

/* Estilos de Atributos - Iguales a la pÃ¡gina de archivo */
#soluciones-single .atributos {
display: flex;
flex-direction: column;
gap: 5px;
margin: 0;
padding-top: 0;
align-self: flex-start;
}

#soluciones-single .group-atributo {
display: flex;
gap: 5px;
margin: 0;
}

#soluciones-single .group-atributo.group-atributo-especificaciones-3x2 {
display: grid !important;
grid-template-columns: repeat(2, 1fr);
grid-auto-rows: auto;
gap: 5px;
}

#soluciones-single .atributo {
font-family: 'Roboto', 'Open Sans', 'Montserrat', 'Segoe UI', Arial, sans-serif;
padding: 2px;
border-radius: 6px;
display: flex;
align-items: center;
justify-content: center;
min-height: 60px;
}

#soluciones-single .atributo p {
margin: 0;
padding: 12px 10px;
text-align: center;
border-radius: 4px;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
min-height: 60px;
font-size: 1.1rem !important;
line-height: 1.1;
width: 100%;
box-sizing: border-box;
}

#soluciones-single .atributo p span {
display: block;
font-size: 0.65rem;
font-style: normal;
font-weight: 400;
margin-top: 2px;
line-height: 1.1;
opacity: 1;
}

/* Atributo Fuego */
#soluciones-single .atributo.fuego {
background-color: #F2F2F2 !important;
border: 2px solid #ff0000;
width: 100%;
padding: 0 !important;
}

#soluciones-single .atributo.fuego p {
background-color: #F2F2F2 !important;
color: #000000 !important;
border: none !important;
font-size: 1.4rem !important;
font-weight: 600 !important;
font-family: 'Roboto', 'Open Sans', 'Montserrat', 'Segoe UI', Arial, sans-serif;
padding: 12px 15px !important;
line-height: 1;
}

/* Atributo Certificado */
#soluciones-single .atributo.certificado {
background-color: #F2F2F2 !important;
border: 2px solid #ff0000;
width: 100%;
padding: 0 !important;
}

#soluciones-single .atributo.certificado p {
background-color: #F2F2F2 !important;
color: #000000 !important;
border: none !important;
padding: 12px 15px !important;
font-family: 'Roboto', 'Open Sans', 'Montserrat', 'Segoe UI', Arial, sans-serif;
font-size: 1.2rem !important;
font-weight: 600 !important;
line-height: 1.1 !important;
min-height: 60px !important;
}

#soluciones-single .atributo.certificado p span {
font-size: 0.8rem !important;
font-weight: 400 !important;
margin-top: 0 !important;
margin-bottom: 4px !important;
line-height: 1.1 !important;
display: block !important;
}

/* Atributo Dimensiones */
#soluciones-single .atributo.dimensiones {
background-color: #628C9A;
}

#soluciones-single .atributo.dimensiones p {
color: #FFFFFF !important;
font-family: 'Roboto', 'Open Sans', 'Montserrat', 'Segoe UI', Arial, sans-serif;
font-size: 1.25rem !important;
font-weight: 400 !important;
padding: 12px 10px !important;
line-height: 1.1;
min-height: 60px !important;
}

#soluciones-single .atributo.dimensiones p span {
color: #FFFFFF !important;
font-size: 0.75rem !important;
font-weight: 400 !important;
font-style: normal !important;
margin-top: 3px !important;
line-height: 1.1 !important;
display: block !important;
}

/* Atributo AcÃºstica */
#soluciones-single .atributo.acustica {
background-color: #314F65;
}

#soluciones-single .atributo.acustica p {
color: #FFFFFF !important;
font-family: 'Roboto', 'Open Sans', 'Montserrat', 'Segoe UI', Arial, sans-serif;
font-size: 1.25rem !important;
font-weight: 400 !important;
padding: 12px 10px !important;
line-height: 1.1;
min-height: 60px !important;
}

#soluciones-single .atributo.acustica p span {
color: #FFFFFF !important;
font-size: 0.75rem !important;
font-weight: 400 !important;
font-style: normal !important;
margin-top: 3px !important;
line-height: 1.1 !important;
display: block !important;
}

/* Atributo TÃ©rmica */
#soluciones-single .atributo.termica {
background-color: #297ED1;
}

#soluciones-single .atributo.termica p {
color: #FFFFFF !important;
font-family: 'Roboto', 'Open Sans', 'Montserrat', 'Segoe UI', Arial, sans-serif;
font-size: 1.25rem !important;
font-weight: 400 !important;
padding: 12px 10px !important;
line-height: 1.1;
min-height: 60px !important;
}

#soluciones-single .atributo.termica p span {
color: #FFFFFF !important;
font-size: 0.75rem !important;
font-weight: 400 !important;
font-style: normal !important;
margin-top: 3px !important;
line-height: 1.1 !important;
display: block !important;
}

/* Atributo Huella HÃ­drica y Carbono */
#soluciones-single .atributo.huellahidrica,
#soluciones-single .atributo.huellacarbono {
flex: 1 1 50%;
width: auto;
background-color: #FFF;
}

#soluciones-single .atributo.huellahidrica {
border: 2px solid #85CCEB !important;
}

#soluciones-single .atributo.huellacarbono {
border: 2px solid #00B050 !important;
}

#soluciones-single .atributo.huellahidrica p {
background-color: #FFF !important;
color: rgb(0, 0, 0) !important;
border-radius: 10px;
margin: 0;
font-family: 'Roboto', 'Open Sans', 'Montserrat', 'Segoe UI', Arial, sans-serif;
font-size: 1.25rem !important;
font-weight: 400 !important;
padding: 12px 10px !important;
line-height: 1.1;
min-height: 60px !important;
}

#soluciones-single .atributo.huellahidrica p span {
font-size: 0.9rem !important;
font-weight: 400 !important;
font-style: normal !important;
margin-top: 3px !important;
line-height: 1.1 !important;
display: block !important;
}

#soluciones-single .atributo.huellacarbono p {
background-color: #FFF !important;
color: rgb(0, 0, 0) !important;
border-radius: 10px;
margin: 0;
font-family: 'Roboto', 'Open Sans', 'Montserrat', 'Segoe UI', Arial, sans-serif;
font-size: 1.25rem !important;
font-weight: 400 !important;
padding: 12px 10px !important;
line-height: 1.1;
min-height: 60px !important;
}

#soluciones-single .atributo.huellacarbono p span {
font-size: 0.9rem !important;
font-weight: 400 !important;
font-style: normal !important;
margin-top: 3px !important;
line-height: 1.1 !important;
display: block !important;
}

/* Atributo Distancia Montantes */
#soluciones-single .atributo.distancia-montantes {
background-color: #628C9A !important;
border: none !important;
width: 100%;
padding: 0 !important;
}

#soluciones-single .atributo.distancia-montantes p {
background-color: #628C9A !important;
color: #FFFFFF !important;
border: none !important;
font-family: 'Roboto', 'Open Sans', 'Montserrat', 'Segoe UI', Arial, sans-serif;
font-size: 1.2rem !important;
font-weight: 600 !important;
padding: 12px 15px !important;
line-height: 1.1 !important;
min-height: 60px !important;
}

#soluciones-single .atributo.distancia-montantes p span {
font-size: 0.8rem !important;
font-weight: 400 !important;
margin-top: 0 !important;
margin-bottom: 4px !important;
line-height: 1.1 !important;
display: block !important;
}

/* Atributo CodificaciÃ³n MINVU */
#soluciones-single .atributo.codificacion-minvu {
background-color: #ffffff !important;
border: 2px solid #000000 !important;
width: 100%;
padding: 0 !important;
}

#soluciones-single .atributo.codificacion-minvu p {
background-color: #ffffff !important;
color: #000000 !important;
border: none !important;
font-family: 'Roboto', 'Open Sans', 'Montserrat', 'Segoe UI', Arial, sans-serif;
font-size: 1.2rem !important;
font-weight: 400 !important;
padding: 12px 10px !important;
line-height: 1.1;
min-height: 60px !important;
}

#soluciones-single .atributo.codificacion-minvu p span {
font-size: 0.9rem !important;
font-weight: 400 !important;
font-style: normal !important;
margin-top: 3px !important;
line-height: 1.1 !important;
display: block !important;
}

/* Grid 3x2 especÃ­fico */
#soluciones-single .group-atributo-especificaciones-3x2 .atributo {
flex: none;
min-width: 0;
width: 100%;
}

#soluciones-single .group-atributo-especificaciones-3x2 .atributo.acustica {
grid-column: span 1;
}

/* Leyenda de Propiedades */
#soluciones-single .x-leyenda-propiedades-contenedor {
display: flex;
align-items: center;
flex-wrap: nowrap;
gap: 8px;
font-family: 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
width: 100%;
justify-content: space-between;
margin-top: 5px;
margin-bottom: 5px;
}

#soluciones-single .x-leyenda-propiedades-item {
display: flex;
align-items: center;
gap: 4px;
flex-shrink: 0;
white-space: nowrap;
}

#soluciones-single .x-leyenda-propiedades-caja {
width: 12px;
height: 12px;
border-radius: 2px;
flex-shrink: 0;
}

#soluciones-single .x-leyenda-propiedades-texto {
color: #616161;
font-size: 15px !important;
font-weight: 500;
letter-spacing: 0.2px;
white-space: nowrap;
}

#soluciones-single .x-leyenda-propiedades-caja.c-fuego {
background-color: #f2f2f2;
border: solid red 2px;
}

#soluciones-single .x-leyenda-propiedades-caja.c-dimensiones {
background-color: #5E8696;
}

#soluciones-single .x-leyenda-propiedades-caja.c-acustica {
background-color: #2E4C60;
}

#soluciones-single .x-leyenda-propiedades-caja.c-termico {
background-color: #297ed1;
}

/* BotÃ³n GuÃ­a de Colores */
#soluciones-single .guia-colores-btn-container {
width: 100%;
text-align: center;
margin-top: 10px;
margin-bottom: 15px;
}

#soluciones-single .guia-colores-btn {
width: 100%;
padding: 10px 15px;
background-color: transparent;
color: #003A70;
border: 1px solid #003A70;
border-radius: 8px;
cursor: pointer;
transition: all 0.3s ease;
text-align: center;
font-size: 14px;
}

#soluciones-single .guia-colores-btn:hover {
background-color: #003A70;
color: #ffffff;
}

/* Ocultar botÃ³n en desktop, mostrar en mobile */
@media (min-width: 768px) {
#soluciones-single .guia-colores-btn-container {
  display: none;
}
}

/* Hacer clickeable x-leyenda-propiedades-contenedor en desktop */
@media (min-width: 768px) {
#soluciones-single .x-leyenda-propiedades-contenedor {
  cursor: pointer;
  transition: opacity 0.3s ease;
}

#soluciones-single .x-leyenda-propiedades-contenedor:hover {
  opacity: 0.7;
}
}

/* Modal GuÃ­a de Colores */
.modal-guia-colores {
display: none;
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: rgba(0, 0, 0, 0.7);
z-index: 9999;
align-items: center;
justify-content: center;
padding: 20px;
box-sizing: border-box;
}

.modal-guia-colores-content {
background-color: #ffffff;
border-radius: 20px;
max-width: 800px;
width: 100%;
padding: 30px;
position: relative;
box-shadow: 0 10px 25px rgba(0,0,0,0.2);
}

.modal-guia-colores-close {
position: absolute;
top: 15px;
right: 20px;
background: transparent;
border: none;
font-size: 24px;
color: #666666;
cursor: pointer;
line-height: 1;
padding: 0;
width: 30px;
height: 30px;
}

.modal-guia-colores-close:hover {
color: #000000;
}

.modal-guia-colores-title {
text-align: center;
margin-bottom: 25px;
font-weight: bold;
color: #333333;
font-size: 18px;
}

.modal-guia-colores-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 20px;
}

.modal-guia-colores-card {
border: 1px solid #e0e0e0;
border-radius: 30px;
overflow: hidden;
background-color: #fafafa;
}

.modal-guia-colores-header {
height: 15px;
width: 100%;
}

.modal-guia-colores-text {
padding: 20px;
font-size: 13px;
color: #444;
line-height: 1.4;
}

@media (max-width: 767px) {
.modal-guia-colores {
  overflow-y: auto;
  align-items: flex-start;
  padding: 20px 10px;
}

.modal-guia-colores-content {
  padding: 20px;
  max-height: 90vh;
  margin: 20px auto;
  overflow-y: auto;
}

.modal-guia-colores-grid {
  grid-template-columns: 1fr;
}
}

/* Imagen Principal Grande */
.imagen-principal {
width: 100%;
margin-top: 0;
margin-bottom: 20px;
display: flex;
align-items: flex-start;
justify-content: center;
overflow: hidden;
max-height: 500px;
border: 0px solid #ccc;
cursor: zoom-in;
}

.imagen-principal img {
width: 100%;
height: 100%;
max-width: 100%;
max-height: 500px;
transition: transform 0.3s ease;
object-fit: contain;
object-position: center center;
border-radius: 8px;
box-shadow: 0 3px 12px rgba(0, 0, 0, 0.1);
}

/* Efecto Hover: Escalado y movimiento */
.imagen-principal:hover img {
transform: scale(2);
transform-origin: center;
}

/* ImÃ¡genes Secundarias en Cuadros PequeÃ±os */
.imagenes-secundarias {
display: grid;
grid-template-columns: repeat(3, 150px);
gap: 10px;
justify-content: center;
width: 100%;
}

.imagen-secundaria {
cursor: pointer;
border: 2px solid #e0e0e0;
border-radius: 8px;
overflow: hidden;
transition: all 0.3s ease;
width: 150px;
height: 150px;
}

.imagen-secundaria.seleccionada {
border: 2px solid #022b81;
}

.imagen-secundaria:hover {
border-color: #022b81;
transform: scale(1.05);
}

.imagenes-secundarias .imagen-secundaria img {
width: 100%;
height: 100%;
display: block;
object-fit: cover;
}

/* TÃ­tulos de Secciones */
.section-title {
font-size: 1.5rem;
font-weight: 600;
color: #022b81;
margin-bottom: 5px;
margin-top: 40px;
}

/* Botones de Descarga */
.documentos-botones {
display: flex;
gap: 15px;
flex-wrap: wrap;
margin-top: 5px;
width: 33.333%; /* 2/6 del ancho = 1/3 */
max-width: 33.333%;
}

.btn-descarga {
flex: 1;
min-width: 0;
padding: 12px 30px;
border-radius: 12px;
text-decoration: none;
color: #fff;
font-weight: 700;
font-size: 1rem;
font-family: 'Roboto', 'Open Sans', 'Montserrat', 'Segoe UI', Arial, sans-serif;
text-align: center;
transition: all 0.3s ease;
border: none;
cursor: pointer;
display: inline-block;
white-space: nowrap;
}

/* Botones azules (CAD, BIM, PDF, ZIP) con gradiente horizontal */
.btn-cad,
.btn-bim,
.btn-pdf,
.btn-zip {
background: linear-gradient(90deg, #20419b 0%, #3380eb 100%);
}

.btn-cad:hover,
.btn-bim:hover,
.btn-pdf:hover,
.btn-zip:hover {
background: linear-gradient(90deg, #1a3579 0%, #2a6bc7 100%);
transform: translateY(-2px);
box-shadow: 0 4px 8px rgba(32, 65, 155, 0.3);
}

/* BotÃ³n rojo (Contacto) con gradiente horizontal */
.btn-contacto {
background: linear-gradient(90deg, #870606 0%, #fe0000 100%);
}

.btn-contacto:hover {
background: linear-gradient(90deg, #6b0505 0%, #e60000 100%);
transform: translateY(-2px);
box-shadow: 0 4px 8px rgba(255, 0, 0, 0.3);
}

/* Responsive */
@media (max-width: 768px) {
.solucion-main-layout {
  flex-direction: column;
}

.solucion-atributos-col,
.solucion-imagenes-col {
  flex: 0 0 100%;
  max-width: 100%;
}

.imagenes-secundarias {
  grid-template-columns: repeat(2, 1fr);
}

.imagen-secundaria {
  width: 100%;
  height: auto;
  min-height: 120px;
}

.imagenes-secundarias .imagen-secundaria img {
  height: auto;
}

.documentos-botones {
  flex-direction: column;
  width: 100% !important;
  max-width: 100% !important;
}

.btn-descarga {
  width: 100%;
}
}

.tabla-atributos.mt-5 {
margin-top: 5px !important;
}

/* Centrar solo el nÃºmero en productos-solucion */
.productos-solucion table td:first-child {
text-align: center;
}

/* ============================================
 Estilos especÃ­ficos para el modal de descarga de archivos
 Solo aplicados en la pÃ¡gina de soluciones-single
 Estilo idÃ©ntico al formulario popup de contacto (modal-content)
 SOBRESCRIBE TODOS LOS ESTILOS EXISTENTES
 ============================================ */

/* Estilos especÃ­ficos para el modal de descarga de archivos - SOBRESCRIBE blue-modal */
#modalDescargaArchivo.blue-modal .modal-content,
#modalDescargaArchivo .modal-content {
background: #ffffff !important;
padding: 40px 50px 50px 50px !important;
border-radius: 30px !important;
position: relative !important;
width: 60dvh !important;
margin-left: auto !important;
margin-right: auto !important;
}

/* Ajustar el diÃ¡logo del modal - centrado con width 70% - SOBRESCRIBE */
#modalDescargaArchivo.blue-modal .modal-dialog,
#modalDescargaArchivo .modal-dialog {
max-width: none !important;
width: 70% !important;
margin: 0 auto !important;
}

#modalDescargaArchivo .modal-body {
color: #333333 !important;
padding: 0 !important;
margin: 0 !important;
}

/* Título del modal de descarga - mismo estilo que modal-guia-colores-title pero en negro */
#modalDescargaArchivo .modal-descarga-title {
text-align: center;
margin-bottom: 25px;
font-weight: bold;
color: #000000 !important;
font-size: 18px;
margin-top: 0;
-webkit-text-fill-color: #000000 !important;
background: none !important;
-webkit-background-clip: unset !important;
background-clip: unset !important;
}

/* BotÃ³n de cerrar - X negra en cÃ­rculo blanco - SOBRESCRIBE a.fix-close */
#modalDescargaArchivo a.fix-close,
#modalDescargaArchivo .fix-close {
position: absolute !important;
top: -30px !important;
right: -30px !important;
cursor: pointer !important;
z-index: 10 !important;
border: none !important;
padding: 0 !important;
width: 36px !important;
height: 36px !important;
border-radius: 50% !important;
display: flex !important;
align-items: center !important;
justify-content: center !important;
transition: all 0.2s ease !important;
margin: 0 !important;
background: #ffffff !important;
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15) !important;
}

#modalDescargaArchivo a.fix-close:hover,
#modalDescargaArchivo .fix-close:hover {
background: #f5f5f5 !important;
box-shadow: 0 3px 8px rgba(0, 0, 0, 0.2) !important;
}

#modalDescargaArchivo a.fix-close i,
#modalDescargaArchivo .fix-close i {
color: #000000 !important;
font-size: 1.3em !important;
line-height: 1 !important;
}

/* Contenedor del formulario - SOBRESCRIBE */
#modalDescargaArchivo .wpcf7-form {
margin: 0 !important;
padding: 0 !important;
width: 100% !important;
}

/* Estilos para los inputs del formulario - SOBRESCRIBE todos los estilos */
#modalDescargaArchivo .wpcf7-form input[type="text"],
#modalDescargaArchivo .wpcf7-form input[type="email"],
#modalDescargaArchivo .wpcf7-form input[type="tel"],
#modalDescargaArchivo .wpcf7-form select,
#modalDescargaArchivo .wpcf7-form-control textarea {
background: #ffffff !important;
border: 1px solid #d0d0d0 !important;
border-radius: 15px !important;
padding: 10px 12px !important;
color: #333333 !important;
width: 100% !important;
margin-bottom: 12px !important;
font-size: 14px !important;
box-sizing: border-box !important;
display: block !important;
font-family: inherit !important;
}

#modalDescargaArchivo .wpcf7-form input[type="text"]:focus,
#modalDescargaArchivo .wpcf7-form input[type="email"]:focus,
#modalDescargaArchivo .wpcf7-form input[type="tel"]:focus,
#modalDescargaArchivo .wpcf7-form select:focus,
#modalDescargaArchivo .wpcf7-form textarea:focus {
outline: none !important;
border-color: #999999 !important;
}

#modalDescargaArchivo .wpcf7-form textarea {
resize: vertical !important;
min-height: 100px !important;
}

/* Select con estilo personalizado - chevron hacia abajo - SOBRESCRIBE */
#modalDescargaArchivo .wpcf7-form select {
appearance: none !important;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E") !important;
background-repeat: no-repeat !important;
background-position: right 12px center !important;
background-size: 12px !important;
padding-right: 35px !important;
cursor: pointer !important;
}

/* BotÃ³n enviar - SOBRESCRIBE .modal-content .wpcf7-form input.wpcf7-submit.btn y .blue-modal .btn - ALINEADO A LA IZQUIERDA */
#modalDescargaArchivo .wpcf7-form input[type="submit"],
#modalDescargaArchivo .wpcf7-form input.wpcf7-submit,
#modalDescargaArchivo .wpcf7-form input.wpcf7-submit.btn,
#modalDescargaArchivo .wpcf7-form-control.wpcf7-submit,
#modalDescargaArchivo .wpcf7-form-control.wpcf7-submit.has-spinner,
#modalDescargaArchivo .wpcf7-form-control.wpcf7-submit.has-spinner.btn,
#modalDescargaArchivo.blue-modal .btn,
#modalDescargaArchivo .modal-content .wpcf7-form input.wpcf7-submit.btn {
background: linear-gradient(90deg, #20419b 0%, #3380eb 100%) !important;
border: none !important;
border-radius: 20px !important;
color: #ffffff !important;
font-weight: 600 !important;
font-size: 16px !important;
padding: 6px 30px !important;
cursor: pointer !important;
transition: all 0.3s ease !important;
width: 35% !important;
margin-top: 20px !important;
margin-bottom: 0 !important;
display: block !important;
text-transform: none !important;
margin-left: 0 !important;
margin-right: auto !important;
text-decoration: none !important;
}

#modalDescargaArchivo .wpcf7-form input[type="submit"]:hover,
#modalDescargaArchivo .wpcf7-form input[type="submit"]:focus,
#modalDescargaArchivo .wpcf7-form input.wpcf7-submit:hover,
#modalDescargaArchivo .wpcf7-form input.wpcf7-submit:focus,
#modalDescargaArchivo .wpcf7-form-control.wpcf7-submit.has-spinner.btn:hover,
#modalDescargaArchivo .wpcf7-form-control.wpcf7-submit.has-spinner.btn:focus,
#modalDescargaArchivo.blue-modal .btn:hover,
#modalDescargaArchivo .modal-content .wpcf7-form input.wpcf7-submit.btn:hover,
#modalDescargaArchivo .modal-content .wpcf7-form input.wpcf7-submit.btn:focus {
background: linear-gradient(90deg, #1a3579 0%, #2a6bc7 100%) !important;
transform: translateY(-2px) !important;
box-shadow: 0 4px 8px rgba(32, 65, 155, 0.3) !important;
color: #fff !important;
border: none !important;
}

/* Labels del formulario - SOBRESCRIBE */
#modalDescargaArchivo .wpcf7-form label {
color: #333333 !important;
font-weight: 400 !important;
margin-bottom: 5px !important;
display: block !important;
font-size: 14px !important;
}

/* PÃ¡rrafos del formulario con espaciado adecuado - SOBRESCRIBE */
#modalDescargaArchivo .wpcf7-form p {
margin: 0 0 12px 0 !important;
padding: 0 !important;
line-height: 1.5 !important;
}

#modalDescargaArchivo .wpcf7-form p:last-of-type {
margin-bottom: 0 !important;
}

/* Contenedor del botÃ³n submit - SOBRESCRIBE - ALINEADO A LA IZQUIERDA */
#modalDescargaArchivo .wpcf7-form p:has(input[type="submit"]),
#modalDescargaArchivo .wpcf7-form p:has(input.wpcf7-submit),
#modalDescargaArchivo .wpcf7-form p:has(.wpcf7-form-control.wpcf7-submit),
#modalDescargaArchivo .wpcf7-form p:has(.wpcf7-form-control.wpcf7-submit.has-spinner.btn) {
text-align: left !important;
margin-top: 20px !important;
margin-bottom: 0 !important;
padding: 0 !important;
}

/* Fallback para navegadores que no soportan :has() */
#modalDescargaArchivo .wpcf7-submit-container {
text-align: left !important;
margin-top: 20px !important;
}

/* Eliminar cualquier espaciado extra de Contact Form 7 - SOBRESCRIBE */
#modalDescargaArchivo .wpcf7-form-control-wrap {
margin: 0 !important;
padding: 0 !important;
display: block !important;
}

/* Mensajes de validaciÃ³n - SOBRESCRIBE */
#modalDescargaArchivo .wpcf7-not-valid-tip {
color: #dc3545 !important;
font-size: 12px !important;
margin-top: 4px !important;
margin-bottom: 0 !important;
padding: 0 !important;
}

#modalDescargaArchivo .wpcf7-response-output {
margin-top: 15px !important;
padding: 12px !important;
border-radius: 8px !important;
font-size: 14px !important;
}

/* Bordes para mensajes de validación CF7 en el modal de descarga */
#modalDescargaArchivo .wpcf7 form.invalid .wpcf7-response-output,
#modalDescargaArchivo .wpcf7 form.unaccepted .wpcf7-response-output,
#modalDescargaArchivo .wpcf7 form.payment-required .wpcf7-response-output {
  border-color: #FFB200 !important;
}

/* Espaciado entre elementos del formulario - SOBRESCRIBE */
#modalDescargaArchivo .wpcf7-form br {
display: none !important;
}

#modalDescargaArchivo .wpcf7-form > * {
margin: 0 !important;
}

/* Estilos para reCAPTCHA - mantener espacio adecuado - SOBRESCRIBE */
#modalDescargaArchivo .wpcf7-form .wpcf7-recaptcha,
#modalDescargaArchivo .wpcf7-form .c4wp_captcha_field {
margin: 15px 0 !important;
}

/* Estilos para el contenedor de captcha y términos */
#modalDescargaArchivo .captcha-terminos-container {
margin-bottom: 15px !important;
}

/* Estilos para el checkbox de términos */
#modalDescargaArchivo .terminos-checkbox-container {
margin-top: 15px !important;
margin-bottom: 15px !important;
}

#modalDescargaArchivo .terminos-checkbox-container label {
display: flex !important;
align-items: flex-start !important;
cursor: pointer !important;
font-size: 14px !important;
color: #333333 !important;
line-height: 1.5 !important;
margin: 0 !important;
padding: 0 !important;
}

#modalDescargaArchivo .terminos-checkbox-container input[type="checkbox"] {
margin-right: 16px !important;
margin-top: 3px !important;
flex-shrink: 0 !important;
width: 18px !important;
height: 18px !important;
cursor: pointer !important;
accent-color: #20419b !important;
}

#modalDescargaArchivo .terminos-checkbox-container label span {
flex: 1 !important;
}

#modalDescargaArchivo .terminos-checkbox-container label span strong a {
color: #20419b !important;
text-decoration: underline !important;
}

#modalDescargaArchivo .terminos-checkbox-container label span strong a:hover {
color: #3380eb !important;
}

/* Asegurar que el modal se muestre correctamente - SOBRESCRIBE */
#modalDescargaArchivo.modal.show .modal-dialog {
top: 5% !important;
transform: none !important;
}

/* SOBRESCRIBE estilos de main.css para inputs con margin */
#modalDescargaArchivo .modal-content .modal-body .wpcf7 form input {
margin: 0 10px 12px 0 !important;
}

/* Centrar modal en mobile */
@media (max-width: 767px) {
  #modalDescargaArchivo.blue-modal .modal-dialog,
  #modalDescargaArchivo .modal-dialog {
    max-width: 90% !important;
    width: 90% !important;
    /* 90% de alto de la pantalla con margen superior/inferior 5% */
    height: 90vh !important;
    max-height: 90vh !important;
    margin-top: 5vh !important;
    margin-bottom: 5vh !important;
    margin-left: auto !important;
    margin-right: auto !important;
    display: flex !important;
    align-items: stretch !important;
    justify-content: center !important;
    padding: 0 !important;
  }
  
  #modalDescargaArchivo.blue-modal .modal-content,
  #modalDescargaArchivo .modal-content {
    width: 100% !important;
    margin: auto !important;
    padding: 30px 20px !important;
    margin-top: 0 !important;
    height: 100% !important;
    max-height: 100% !important;
    overflow-y: auto !important;
    box-sizing: border-box !important;
  }
  
  #modalDescargaArchivo .modal-descarga-title {
    font-size: 16px !important;
    margin-bottom: 20px !important;
    color: #000000 !important;
    -webkit-text-fill-color: #000000 !important;
    background: none !important;
    -webkit-background-clip: unset !important;
    background-clip: unset !important;
  }
  
  /* Asegurar que el botón cerrar esté dentro del modal en mobile */
  #modalDescargaArchivo a.fix-close,
  #modalDescargaArchivo .fix-close {
    top: -20px !important;
    right: -10px !important;
  }

  /* Evitar que el rule global de top desplace el modal */
  #modalDescargaArchivo.modal.show .modal-dialog {
    top: 0 !important;
  }
}

.bi-search {
  -webkit-text-stroke: 2px currentColor;
}

/* Ocultar el botón específicamente en móviles */
@media (max-width: 767px) {
  section#breadcrumb div.container div.row div.col-auto button.btn-volver-soluciones {
      display: none !important;
  }
}

@media (min-width: 768px) {
  section#soluciones-single div.info-solucion div.codigo-volver-row button.btn-volver-soluciones {
      display: none !important;
  }
  #modalDescargaArchivo.modal.fade.blue-modal.show > .modal-dialog > .modal-content { 
    margin-top: 0px 
  }
}
