body {
	font-family: 'Poppins', sans-serif;
	font-size: 1em;
	line-height: 1.32;
	font-weight: 400;
	color: #393036;
}
#home {
	background-image: url("../images/bg-body.svg");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: top -1300px left 1px;
}
#registroPage {
	background-image: url("../images/bg-body.svg");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: top -700px left 1px;
}
#novedadesPage {
	background-image: url("../images/bg-body.svg");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: top -700px left 1px;
}
a:hover {
	color: #0e5c20;
}
h2, h3, h4 {
	display: inline;
}
h4 {
	color: #02852A;
	font-size: 1.35em;
	font-weight: 600;
	margin-bottom: 1.5em;
	line-height: 1.6;
}
.bg-header {
	background-image: url("../images/bg-header.svg");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center -40px;
	z-index: 10;
}
.nav-link {
	font-family: "Gochi Hand", sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 1.75em;
	line-height: 1.4;
	color: #02852A;
}
.icons {
	padding-right: 0;
	padding-left: 0;
	margin-left: -0.4em;
	margin-right: -0.4em
}
#carruselTuFuturo {
	margin-top: -6em;
	height: 751px;
}

#carruselTuFuturo .carousel-inner,
#carruselTuFuturo .carousel-item,
#carruselTuFuturo .carousel-item img {
	height: 100%;
	object-fit: cover;
}

.bg-image {
	background-image: url("../images/bg-foto-exclusivo.svg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	text-align: center;
	padding: 3em;
}
.solicita-practica {
	background-image: url(../images/bg-foto-postula.svg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	text-align: center;
	padding: 3em;
}
.bg-image-caja {
	background-image: url("../images/bg-foto-caja.svg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	text-align: center;
	padding: 3em 1em 1em 1em;
	min-height: 400px;
}
.bg-foto-noticia {
	background-image: url("../images/bg-foto-noticia.svg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	text-align: center;
	padding: 3em 1em 1em 1em;
	min-height: 400px;
}
.bg-image img {
	width: 95%;
	height: auto;
}
.solicita-practica img {
	width: 95%;
	height: auto;
}
.bg-image-caja img {
	width: 95%;
	height: auto;
	margin-bottom: 30px;
}
p {
	font-size: 1em;
	font-weight: 400;
	color: #393036;
	line-height: 1.65;
}
.espaciador {
	height: 65px;
}
.titulo-destacado {
	font-size: 2.8em;
}
.titulo-noticia {
	font-size: 2em;
	line-height: 1.3;
	display: block;
}
.fecha-noticia {
	font-size: 0.8em;
	display: block;
	margin-bottom: 20px;
}
.btn-amarillo {
	background-color: #FFCC00;
	font-size: 1.12em;
	font-weight: 600;
	padding: 12px 34px;
	border-radius: 50px;
	border: 0;
}
.padtop-30 {
	padding-top: 30px;
}
.padtop-50 {
	padding-top: 50px;
}
.padtop-70 {
	padding-top: 70px;
}
.martop-30 {
	margin-top: 30px;
}
.caja-sombra {
	background-color: #fff;
	box-shadow: 0px 3px 8px rgba(38, 77, 43, 18%);
	padding: 22px;
	border-radius: 16px;
}
.img-noticia {
	width: 100%;
	height: auto;
	margin-bottom: 1em;
	margin-top: 1em;
}
.separador {
	background-image: url("../images/separador.svg");
	height: 25px;
	border: 0;
	margin: 3.5em 0;
}
.bg-cierre {
	background-image: url("../images/bg-cierre.svg");
	background-position: bottom -565px center;
	background-repeat: no-repeat;
	background-size: cover;
	padding-bottom: 50px;
}
.iconos {
	background-image: url("../images/bg-iconos.svg");
	background-position: top right -10px;
	background-repeat: repeat-y;
	background-size: 100%;
	padding-bottom: 150px;
}
.foto-galeria {
	background-image: url("../images/bg-foto-galeria.svg");
	background-position: bottom center;
	background-repeat: no-repeat;
	background-size: cover;
}
.galeria {
	margin-right: 1em;
}
.caption {
	background-color: #FFCC00;
	padding: 7px 21px;
	border-radius: 6px;
	font-weight: 700;
	font-size: 1.1em;
	float: right;
	transform: rotate(-3deg);
	margin-top: -1.3em;
	margin-right: 2em;
}
.mini-caption {
	background-color: #FFCC00;
	padding: 7px 21px;
	border-radius: 6px;
	font-weight: 700;
	font-size: 0.88em;
	transform: rotate(-3deg);
	margin-top: -1.3em;
	margin-right: 1em;
	margin-left: 8.6em;
	position: relative;
}
.mini-caption2 {
	background-color: #FFCC00;
	padding: 7px 21px;
	border-radius: 6px;
	font-weight: 700;
	font-size: 0.88em;
	transform: rotate(-3deg);
	margin-top: -1.3em;
	margin-right: 1em;
	margin-left: 4.6em;
	position: relative;
}
.formRegistro {
	background-color: fff;
	border: solid 1px #2B8B42;
	border-radius: 8px;
	width: 99%;
	height: 64px;
	padding: 18px;
	font-size: 0.9em;
}
input::placeholder {
	font-weight: 400;
	opacity: 0.32;
	color: #4C5158;
}
.caja-check {
	height: 32px;
	width: 32px;
	display: inline;
	margin-right: 0.65em;
	border: solid 1px #2B8B42;
}
.txt-check {
	margin-top: -0.5em;
}
.txt-check a {
	color: #2B8B42;
	text-decoration: none;
}
.texto-foto {
	font-size: 0.78em;
	font-weight: 300;
	text-align: right;
	margin-right: 1.5em;
}
.ver-galeria {
	color: #2B8B42;
}
.contenedor {
	position: relative;
	width: 23%;
	margin-right: 1.65em;
	margin-bottom: 1.65em;
	float: left
}
.contenedorNoticias {
	position: relative;
	width: 23%;
	margin-right: 0.65em;
	margin-bottom: 1em;
	float: left
}
.min-galeria {
	width: 100%;
	height: auto;
	display: block;
	cursor: pointer;
}
.overlay {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	height: 100%;
	width: 100%;
	opacity: 0;
	transition: .35s ease;
	background-color: rgba(255, 204, 0, 0.70);
	border-radius: 8px;
	cursor: pointer;
}
.contenedor:hover .overlay {
	opacity: 0.92;
}
.contenedorNoticias:hover .overlay {
	opacity: 0.92;
}
.lupa {
	position: absolute;
	top: 42%;
	left: 42%;
	cursor: pointer;
}
.lupa-mini {
	position: absolute;
	top: 40%;
	left: 41%;
	cursor: pointer;
}
.lupa-mini img {
	max-width: 75%;
}
.noticia-relacionada {
	margin-bottom: 1.5em;
}
.titulo-relacionado {
	color: #393036;
	font-size: 2em;
	line-height: 1.6;
}
.bg-galeria-fotos {
	background-image: url("../images/bg-galeria-fotos.svg");
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}
.footer {
	background-image: url("../images/bg-footer.svg");
	background-position: bottom center;
	background-repeat: no-repeat;
	background-size: cover;
	margin-top: -115px;
	height: 186px;
	padding-top: 162px;
	font-size: 0.75em;
	text-align: center;
	text-indent: -200px;
}
.skeleton-carousel {
	width: 100%;
	height: 751px;
	background: #f0f0f0;
	position: relative;
	overflow: hidden;
}

.skeleton-placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, 
		rgba(240, 240, 240, 0.8) 0%,
		rgba(224, 224, 224, 0.9) 20%,
		rgba(240, 240, 240, 0.8) 40%,
		rgba(224, 224, 224, 0.9) 60%,
		rgba(240, 240, 240, 0.8) 80%,
		rgba(224, 224, 224, 0.9) 100%
	);
	background-size: 200% 100%;
	animation: shimmer 2s infinite;
	filter: blur(8px);
	transform: scale(1.1);
}

@keyframes shimmer {
	0% {
		background-position: -200% 0;
	}
	100% {
		background-position: 200% 0;
	}
}

.skeleton-gallery {
    display: flex;
    flex-wrap: wrap;
    gap: 1.65em;
    padding: 1em;
}

.skeleton-item {
    width: calc(25% - 1.65em);
    margin-bottom: 1.65em;
    position: relative;
}

.skeleton-item .skeleton-placeholder {
    width: 100%;
    padding-bottom: 100%;
    background: linear-gradient(90deg, 
        rgba(240, 240, 240, 0.8) 0%,
        rgba(224, 224, 224, 0.9) 20%,
        rgba(240, 240, 240, 0.8) 40%,
        rgba(224, 224, 224, 0.9) 60%,
        rgba(240, 240, 240, 0.8) 80%,
        rgba(224, 224, 224, 0.9) 100%
    );
    background-size: 200% 100%;
    animation: shimmer 2s infinite;
    filter: blur(8px);
    transform: scale(1.1);
    border-radius: 8px;
}

.skeleton-text {
    padding: 1em;
}

.skeleton-line {
    height: 1em;
    background: linear-gradient(90deg, 
        rgba(240, 240, 240, 0.8) 0%,
        rgba(224, 224, 224, 0.9) 20%,
        rgba(240, 240, 240, 0.8) 40%,
        rgba(224, 224, 224, 0.9) 60%,
        rgba(240, 240, 240, 0.8) 80%,
        rgba(224, 224, 224, 0.9) 100%
    );
    background-size: 200% 100%;
    animation: shimmer 2s infinite;
    margin-bottom: 1em;
    border-radius: 4px;
}

.skeleton-line:nth-child(1) { width: 100%; }
.skeleton-line:nth-child(2) { width: 80%; }
.skeleton-line:nth-child(3) { width: 60%; }

.img-noticia-container {
    margin: 15px 0;
    width: 100%;
    height: 200px;
    overflow: hidden;
    border-radius: 8px;
}

.img-noticia {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.skeleton-image {
    width: 100%;
    height: 100%;
    background: #f0f0f0;
    position: relative;
    overflow: hidden;
}

.skeleton-image .skeleton-placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
}

@keyframes shimmer {
    0% {
        background-position: -200% 0;
    }
    100% {
        background-position: 200% 0;
    }
}

.titulo-noticia-link {
    color: #02852A;
    text-decoration: none;
    transition: color 0.3s ease;
}

.titulo-noticia-link:hover {
    color: #02852A;
    text-decoration: none;
}

/* Form validation styles */
.error {
    color: #dc3545;
    font-size: 12px;
    margin-top: 4px;
    display: block;
}

.formRegistro.ng-invalid.ng-touched {
    border-color: #dc3545;
    background-color: #fff8f8;
}

.formRegistro.ng-valid.ng-touched {
    border-color: #28a745;
    background-color: #f8fff8;
}

button:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Password requirements styles */
.password-requirements {
    margin-top: 10px;
    padding: 10px;
    background-color: #f8f9fa;
    border-radius: 4px;
    font-size: 12px;
}

.requirement {
    margin: 5px 0;
    color: #6c757d;
    display: flex;
    align-items: center;
}

.requirement i {
    margin-right: 8px;
    width: 16px;
    text-align: center;
}

.requirement i.fa-check {
    color: #28a745;
}

.requirement i.fa-times {
    color: #dc3545;
}

.requirement.valid {
    color: #28a745;
}

/* Add Font Awesome for icons */
@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.4/css/all.min.css');

/* Form field focus styles */
.formRegistro:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(40, 167, 69, 0.25);
    border-color: #28a745;
}

.formRegistro.ng-invalid.ng-touched:focus {
    box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.25);
    border-color: #dc3545;
}

/* Tooltip styles for validation messages */
[data-tooltip] {
    position: relative;
}

[data-tooltip]:hover::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    padding: 5px 10px;
    background-color: #333;
    color: white;
    border-radius: 4px;
    font-size: 12px;
    white-space: nowrap;
    z-index: 1000;
}

.form-label {
    display: block;
    margin-bottom: 5px;
    font-weight: 500;
    color: #333;
    font-size: 14px;
}

.formRegistro {
    width: 100%;
    padding: 8px 12px;
    margin-bottom: 5px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 14px;
}

.formRegistro:focus {
    border-color: #ffc107;
    outline: none;
    box-shadow: 0 0 0 2px rgba(255, 193, 7, 0.25);
}

.formRegistro::placeholder {
    color: #999;
    font-size: 13px;
}

select.formRegistro {
    appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 8px center;
    background-size: 16px;
    padding-right: 30px;
}

input[type="date"].formRegistro {
    padding-right: 8px;
}

.error-input {
    border-color: #dc3545 !important;
    background-color: #fff8f8 !important;
}

.error-input:focus {
    border-color: #dc3545 !important;
    box-shadow: 0 0 0 2px rgba(220, 53, 69, 0.25) !important;
}

/* Estilos personalizados para el autocompletado de UI Bootstrap */
.uib-typeahead-popup.dropdown-menu {
  background: #fff;
  border: 1px solid #ced4da;
  border-radius: 0.25rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  font-family: 'Poppins', sans-serif;
  color: #495057;
  z-index: 2000;
}

.uib-typeahead-popup .uib-typeahead-match {
  padding: 8px 16px;
  cursor: pointer;
  color: #495057;
  background: #fff;
  border-bottom: 1px solid #f0f0f0;
}

.uib-typeahead-popup .uib-typeahead-match.active,
.uib-typeahead-popup .uib-typeahead-match:hover {
  background: #ffe066;
  color: #333;
  font-weight: 600;
}

.uib-typeahead-popup .uib-typeahead-match:last-child {
  border-bottom: none;
}

/* --- Ajuste de altura para Select2 para igualar a los inputs normales --- */
.select2-container--bootstrap .select2-selection--single {
    height: 64px; /* Ajusta este valor si tus inputs tienen otra altura */
    padding: 6px 12px;
    font-size: 16px;
    line-height: 1.42857143;
    border-radius: 4px;
    border: 1px solid #ccc;
    box-sizing: border-box;
    display: flex;
    align-items: center;
}

.select2-container--bootstrap .select2-selection--single .select2-selection__rendered {
    line-height: 28px; /* Ajusta según la altura */
    padding-left: 0;
    display: flex;
    align-items: center;
    height: 100%;
}

.select2-container--bootstrap .select2-selection--single .select2-selection__arrow {
    height: 100%;
    top: 0;
    right: 6px;
}

/* Carousel responsive para móvil */
.carousel-item img {
    width: 100%;
    height: auto;
    max-height: 60vh;
    object-fit: cover;
    border-radius: 16px;
}

@media (max-width: 768px) {
    .carousel-item img {
        max-height: 40vh;
        border-radius: 8px;
    }
    .carousel-caption {
        font-size: 14px;
        padding: 8px;
    }
}

@media (max-width: 576px) {
    .carousel-caption {
        font-size: 12px;
        padding: 4px;
        background: rgba(0,0,0,0.3);
        border-radius: 6px;
    }
    .carousel-item img {
        max-height: 32vh;
    }
}

/* Separación superior para el carousel respecto al menú */
.container-fluid[ng-controller="CarouselController"] {
    margin-top: 45px;
}

@media (max-width: 768px) {
    .container-fluid[ng-controller="CarouselController"] {
        margin-top: 48px;
    }
}