/*================================================================================
* Colores este anio:2025
Primario: #611232
Primario Light: #9b2247
Secundario: #a57f2c
Negro: #161a1d
Gris: #98989A
Verde: #002f2a
================================================================================*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans:ital,wght@0,100..900;1,100..900&display=swap');
@font-face {
    font-family: 'Patria';
    font-style: normal;
    font-weight: 400;
    src: url("https://framework-gb.cdn.gob.mx/applications/cms/fonts/Patria_Regular.otf") format("opentype");
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215, U+E0FF, U+EFFD, U+F000;
}


@font-face {
	font-family: 'Carbon';
	src:url('../fonts/ecoems/CarbonBlock.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
}



:root {
  --primary-color: #9b2247;
  --primary-light-color: #611232;
  --primary-strong-color:#691a32;
  --secondary-color: #f3e8ca;
  --third-color: #ae851c;
  --font-size-large: 1rem;
}

/*========================== INICIO ===========================*/

.cdosbackground{
   background-color: #fff;
    background-repeat: no-repeat;
    background-attachment: fixed;
    background-image: url(../../imgsys/fondoextemporaneos.png);
    background-size:  cover;
    background-position: left top;
}
.contentArea{
  background-repeat: no-repeat;
  background-image:url(../../imgsys/dibujoinferior.png);
  background-size:  25% auto;
  background-position:left bottom;
}
.titleGral {
  background-color: var(--primary-color);
  color: #fff;
  font-weight: bold;
  font-size: 1rem;
  padding: 20px 10px;
  text-align: center;
  position: relative;
  min-height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  
  /* Background para desktop */
  background-repeat: no-repeat;
  background-image: url(../../imgsys/banner1duo.png);
  background-size: cover;
  background-position: left top;
  
  /* Contenedor del texto con overlay */
  position: relative;
}

.titleGral::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.01);
  z-index: 1;
}

.titleGral .banner-content {
  position: relative;
  z-index: 2;
  max-width: 50%;
  margin: 0 auto;
}

.titleGral h1 {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 900;
  line-height: 1.2;
  color:var(--third-color);
}

.titleGral p {
  margin: 10px 0 0 0;
  font-size: 1.1rem;
  font-weight: 400;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.7);
  line-height: 1.4;
}

/* Responsive para móviles */
@media (max-width: 1200px) {
  .titleGral {
    background-color: var(--primary-color);
    min-height: 100px;
    padding: 15px 10px;
  }
  
  .titleGral::before {
    display: none;
  }
  
  .titleGral h1 {
    font-size: 1.8rem;
  }
  
  .titleGral p {
    font-size: 1rem;
  }
}

/* Responsive para tablets */
@media (min-width: 769px) and (max-width: 1024px) {
  .titleGral {
    min-height: 100px;
    background-size:  cover;
    background-position: left top;
  }
  
  .titleGral h1 {
    font-size: 2rem;
  }
  
  .titleGral p {
    font-size: 1rem;
  }
}

/* Responsive para pantallas medianas */
@media (min-width: 1025px) and (max-width: 1366px) {
  .titleGral {
    background-size:  cover;
    min-height: 100px;
    background-position: left top;
  }
}

/* Responsive para pantallas grandes */
@media (min-width: 1367px) {
  .titleGral {
    background-size:  cover;
    min-height: 100px;
    background-position: left top;
  }
}

/* Responsive para tablets */
@media (min-width: 769px) and (max-width: 1024px) {
  .titleGral h1 {
    font-size: 2rem;
  }
  
  .titleGral p {
    font-size: 1rem;
  }
}

/* Mejoras adicionales para el banner */
.titleGral {
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  margin-bottom: 0;
}

.titleGral .banner-content {
  animation: fadeInUp 0.8s ease-out;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Mejoras para dispositivos muy pequeños */
@media (max-width: 480px) {
  .titleGral {
    min-height: 80px;
    padding: 10px 5px;
  }
  
  .titleGral h1 {
    font-size: 1.5rem;
  }
  
  .titleGral p {
    font-size: 0.9rem;
  }
}

/* Mejoras para dispositivos grandes */
@media (min-width: 1200px) {
  .titleGral {
    min-height: 100px;
  }
  
  .titleGral h1 {
    font-size: 2rem;
  }
  
  .titleGral p {
    font-size: 1.1rem;
  }
}

/* Estilos para la imagen de nueva oferta */
.nueva-oferta-image {
  position: absolute;
  display: none;
  border:1px solid #000;
  top: 30%;
  right: 5%;
  width: 80%;
  height: auto;
  transform: translateY(-20%);
  z-index: 10;
  border: none;

}

.login-form{
  background-color: #fff;
  padding: 10px;
  border-radius: 10px;
  color:#000;
  margin:1%;
}

/* Responsive para la imagen */
/* cuando es mas de 768px */
@media (max-width: 768px) {
  .nueva-oferta-image {
    width: 40%;
    right: 1%;
    max-width: 400px;
  }
}

/* cuando es hasta 480px */
@media (max-width: 480px) {
  .nueva-oferta-image {
    display: none;
  }
}

/* cuando es mas de 1200px */
@media (min-width: 1200px) and (max-width: 1366px) {
  .nueva-oferta-image {
    width: 85%;
    right: 0%;
    max-width: 700px;
  }
  
}

@media (min-width: 1367px) {
  .nueva-oferta-image {
    display: block;
    width: 85%;
    right: 0%;
    max-width: 700px;
  }
  
}

.logoConcursoAsign{
    position: fixed;
  width:100%;
  /* text-align: center; */
  margin-left: 2%;
    margin-top: 2%;
}


.imgConcursoLogin{
  width:98%;

  text-align: center;
}
.imgMonito{
  width:60%;
  margin-left:10%;
  
}
.divSalirLogin{
    border:0 solid #000;
    padding-top:3%;
    display:inline-block;
    width:100%;
      margin-top:5%;
}
.btnSalirLogin{
  border:1px solid #616161;
  padding:10px 20px;
  font-weight:bold;
  font-size:1.5em;
  color:#616161;

}

.logoFormalogin{
   width:100%;
  text-align: right;
  margin-top:2%;
}
.tituloFormaLogin{
  font-weight: bold;
  font-size:1.5em;
  color:#fff;
  text-align:right;
}
.tituloFormaLoginVerde{
	border:0 solid #000;
	text-align:center;
	color:#611232;
}
.tituloFormaLoginVerde>span{
	padding:10px 15px;
	border:0 solid #000;
	width:80%;
	text-align:center;
	background-color:#611232;
	color:#fff;
	border-top-right-radius: 15px 20px;
	border-bottom-right-radius: 15px 20px;
	border-top-left-radius: 15px 20px;
	border-bottom-left-radius: 15px 20px;
}

.tituloFormaLoginWhite{
border:0 solid #000;
  color:#fff;
  display:inline-block;
}
.text-instructions2{
  border:0 solid #000;
  color:#3d3d3d;
  font-size:1.2em;

  width:80%;
  text-align:center;
  margin:auto;
  margin-top:10%;

  font-weight:bold;
  font-size:1.3em;
}
.formaLogin{
  border:0 solid #000;
  background-color:rgba(255, 255, 255, 0.9);
  margin-right: 1px;
  float:right;

  border-radius: 20px 20px 20px 20px;
  -moz-border-radius: 20px 20px 20px 20px;
  -webkit-border-radius: 20px 20px 20px 20px;

}
a.showDatesAsign,a.showDatesAsign:hover{
  color:#f00;
}
button.btnSecondaryAnio{
  background-color: var(--third-color);
  color: #fff;
  font-weight: bold;
  font-size:1.3em;
  border-radius: 10px;
  padding: 10px 20px;
  margin-left:auto;
  margin-right:auto;
  margin-top: 10px;
  width:80%;
  border:none;
}



@media only screen and (max-width:600px){
  .columnaIzq{
    display:none;
  }
}
@media only screen and (min-width:1200px){
  .mainContent{
    /*width:1500px;*/
    margin:auto;
  }
}
/* ================= Salir =================== */
.divSalir{
    border:0 solid #000;
    display:inline-block;
    width:100%;
}


/* ================= Columna izq =================== */
.columnClass{

    float:left;
    height: 100%;
    background-color: #fff;
    background-repeat: no-repeat;
    background-attachment: fixed;
    background-image: url(../../imgsys/fondoeje2.jpg);
    background-size:  auto 100%;
    background-position: left bottom;

      /*
background-clip: padding-box;
      background: url(images/bg.jpg) no-repeat center center fixed;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;


    background-size: cover;

    background-size: auto 100px;
    background-repeat: no-repeat;
    background-position: center bottom;

    background-color: #FAFAFA;#555555

    background-repeat: repeat-x;
    */

    /**/
}
/* ================= Contenido =================== */
.columnContainer{
    border:1px solid #000;
}


.headerColorsinpadding.row, .contentRow.row{
    border:1px solid #000;
    width:100%;
    margin:0;
    padding:10px 0;
}

.headerColorsinpadding.row{
    background-color:#240085;
    color:#fff;
}

.headerColorsinpadding .col {
    margin-right: 0;
    margin-left: 0;
}
.headerTitleLogin{
    margin-left:25%;
    width:45%;
    display:inline-block;
    padding-top:1%;
    text-align:center;
    color:#fff;
    font-size: 1.3em;
}

.titlelogin{
  color:#C8102E;
  font-weight: bold;
  font-size: 2rem;
  margin-block-start: 0.5em;
  margin-block-end: 0.5em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;

  border: 1px solid #611232;
  border-radius: 8px;
  text-align: center;
}

.titlelogin2{
    color:#611232;
    font-weight: bold;
    font-size: 2rem;
    margin-block-start: 0.5em;
    margin-block-end: 0.5em;
    margin-inline-start: 0px;
    margin-inline-end: 0px;
    text-align: center;
}


.loginTextAuth{
    max-width: 90%;
    margin: auto;
    font-size: 1.3rem;
    color:#F44336;
    padding:0 10px;
    text-align:center;
}
.codigoAuth{
    border:0 solid #000;
    text-align:center;
    width:50px;
}
.backgroundHeader{

  background-image:url('../../imgsys/bannerprincipalsolo.png');
  background-repeat:no-repeat;
  background-position: center;
  background-color: transparent;
  background-size: 100% auto;
  min-height:100px;

  /*
  background-attachment:fixed;
  background-size: cover;
  webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  background-size: 100% auto;
  background-position: left top;
  background-position: 50% 50%;
  height: calc(100% - 10px);
  */
}
.spaceNglob{
  border:0 solid #000;
  display:inline-block;
  width:150px;
}

.spaceNglob2{
  border:0 solid #000;
  display:inline-block;
  width:200px;
}



.contentRowMonitos{
  display: flex;
  align-items: stretch; /* Asegura que las columnas ocupen todo el espacio vertical */
  height: 100vh; /* Ocupa toda la altura de la ventana */
}
.rowspacemonito{
  padding-top:200px;
}
.divmonito{
  border:0 solid #000;   
  position: absolute;
  bottom: 0;
  padding-left: 5%;
  z-index: 1000; 
}

@media only screen and (min-width:900px){ 
  .divmonito{
      padding-left: 1%;
  }
}
.imgMonitolog {
  position:absolute;
  bottom:1%;
  left:10%;
}
.imgMonitolog2 {
  display: flex;
  justify-content: center;
  align-items: flex-end; /* Alinea el monito al fondo */
}