@import url('https://fonts.googleapis.com/css2?family=Source+Sans+3:ital,wght@0,200..900;1,200..900&display=swap');
 
/*========== Font > Fontawesome */

@import url('fontawesome.min.css');
@import url('brands.min.css');
@import url('regular.min.css');
@import url('solid.min.css');
@import url('light.min.css');

 
 :root {
/* 🎯 Colores base */
  --color-white: #fff;
  --color-black: #000;
  --color-light: #efefef;
  --color-lighter: #f2f2f2;
  --color-dark: #1f1f1f;
  --color-darker: #444;
  --color-gray: #5f5f5f;
  }
body {
	letter-spacing: 0;
	background: #ffffff;
}
.collapsible .collapsible {
	list-style-type: none;
}
.collapsible .collapsible li {
	padding-left: 0;
}
.collapsible .collapsible li:before {
	content: '';
}
.slides {
	width: 100%;
	height: 407px;
	margin: auto;
	overflow: hidden;
	aspect-ratio: 1440 / 407;
	max-width: 100%;
	height: auto;
	max-height: 407px;
	min-height: 250px;
	position: relative;
}
.slide-item {
	background: #294787;
	position: absolute;
	height: 100%;
	top: 0;
	left: 0;
	width: 100%;
	opacity: 0;
	transition: opacity .6s ease-in-out;
}
.slide-item:first-child {
	position: relative;
	opacity: 1;
}
.slides .cont-slider-home {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	z-index: 3;
	text-align: center;
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	height: 100%;
	margin: auto;
}
.titulo-slider-home {color: #FFF;
	text-align: center;
	font-family: "Source Sans 3";
	font-size: 2.5rem;
	font-style: normal;
	font-weight: 500;
	line-height: 1em;
	text-transform: capitalize;}
.slide-item img.img-slide-home {
		mix-blend-mode: exclusion;
		position: relative;
		max-width: 100%;
		height: 100%;
		object-fit: cover;
		top: 0;
		left: 0;
		width: 100%;
	}

.info-bar-rect {
		width: 100%;
		margin: auto;
		background: #294787;
		color: #fff;
		text-align: center;
		max-width: 100%;
		font-family: "Source Sans 3";
		font-size: 1rem;
		font-weight: 400;
		line-height: 1rem;
		padding: 0.6rem 0;
		position: sticky;
        top: var(--header-height, 0px); /* se actualiza vía JS */
        z-index: 9; /* por debajo del header */
        transition: all 0.3s ease;
}
.info-bar-rect .justify-center-md {
    transition: all 0.3s ease;
}
.info-bar-rect.info-bar-scrolling .justify-center-md {
    justify-content: center!important;
    font-size: .9rem;
}
.servicios-section {font-family: "Source Sans 3";}
.servicios-grid-botones {
		/* gap: 15px; */
		
	}

.caluga-icon-home {
	width: calc(214px / 1 - 0px);
	height: 239px;
	border-radius: 15px;
	background: #294787;
	text-align: center;
	position: relative;
	overflow: hidden;
	display: block;
	cursor: pointer;
	text-decoration: none !important;
	color: inherit;
	/* aspect-ratio: 214 / 239; */
	transition: all 0.15s ease-in-out;
    -webkit-transition: all 0.15s ease-in-out;
    -moz-transition: all 0.15s ease-in-out;
    background-color: #294787;
}
.caluga-icon-home:hover .img_overlay_item_caluga {
    opacity: .2;
}
.caluga-icon-home .cont-caluga {
 	transition: all 0.15s ease-in-out;
    -webkit-transition: all 0.15s ease-in-out;
    -moz-transition: all 0.15s ease-in-out;   
}
.caluga-icon-home:hover .cont-caluga {
    transform: scale(1.05);
}
.servicios-grid-botones .caluga-icon-home {
	/* max-width: calc(25% - 8px); */
	flex-shrink: 0;
	user-select: none;
	-webkit-tap-highlight-color: transparent;
	flex: auto 0 0;
	/* width: calc(100% / 4 - 8px); */
}
	
.servicios-grid-botones .carousel-track {gap: 10px;}

.caluga-icon-home:before {
	content: "";
	position: absolute;
	background: rgba(33, 52, 94, 0.5);
	width: 100%;
	height: 100%;
	z-index: 1;
	left: 0;
	top: 0;
}
.caluga-icon-home.sis_gestion_causas:before {
	content: "";
	position: absolute;
	background: rgba(33, 52, 94, 0.25);
	width: 100%;
	height: 100%;
	z-index: 1;
	left: 0;
	top: 0;
}

.sgdc {margin-right: 15px;}
.cont-caluga {
	width: 145px;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	flex-direction: column;
	margin: auto;
	gap: 10px;
	position: relative;
	z-index: 2;
	max-width: 90%;
}
.sgdc .cont-caluga {
	height: calc(100% / 1 - 30px);
}
.cont-caluga img {max-width: 100%;	width: 71px;}
.caluga-icon-home h4 {
	color: #FFF;
	text-align: center;
	font-family: "Source Sans 3";
	font-size: 18px;
	font-style: normal;
	font-weight: 700;
	line-height: 113%;
	letter-spacing: 0;
	margin: 0;
}
.img_overlay_item_caluga {
	
	position: absolute;
	max-width: 100%;
	height: 100%;
	object-fit: cover;
	top: 0;
	left: 0;
	width: 100%;
}

.exclusion {mix-blend-mode: exclusion;}
.displayflex {
	display: flex;
}
.overflowhidden {overflow: hidden;}
.pt-40px {padding-top: 40px;}
.pb-40px {padding-bottom: 40px;}

/* ========================================================= */
/* ðŸ–¥ï¸ DISPLAY Y VISIBILIDAD */
/* ========================================================= */
.d-none { display: none; }
.d-block { display: block; }
.d-inline { display: inline; }
.d-inline-b { display: inline-block; }
.d-flex { display: flex; }
.d-grid { display: grid; }
.invisible { visibility: hidden; }


/* ========================================================= */
/* ðŸ“ FLEXBOX Y ALINEACIÃ“N */
/* ========================================================= */
.flex-col { flex-direction: column; }
.flex-row { flex-direction: row; }
.flex-wrap { flex-wrap: wrap; }
.flex-grow { flex-grow: 1; }

/* Align Items (AlineaciÃ³n vertical) */
.items-start { align-items: flex-start; }
.items-center { align-items: center; }
.items-end { align-items: flex-end; }

/* Justify Content (AlineaciÃ³n horizontal) */
.justify-start { justify-content: flex-start; }
.justify-center {justify-content: center;}
.justify-end { justify-content: flex-end; }
.justify-between { justify-content: space-between; }
.justify-around { justify-content: space-around; }

.flex-w-50 {flex: 50%;}
.flex-w-full {flex: 100%;}

/* ========================================================= */
/* ðŸ“Œ POSICIONAMIENTO Y OVERFLOW */
/* ========================================================= */
.pos-rel { position: relative; }
.pos-abs { position: absolute; }
.pos-fixed { position: fixed; }
.pos-sticky { position: sticky; }

/* Atajo para top:0; right:0; bottom:0; left:0; */
.pos-0 { top: 0; right: 0; bottom: 0; left: 0; }

/* Overflow */
.overflow-h { overflow: hidden; }
.overflow-a { overflow: auto; }
.overflow-x-h { overflow-x: hidden; }
.overflow-y-s { overflow-y: scroll; }


/* ========================================================= */
/* ðŸ“ DIMENSIONES (WIDTH & HEIGHT) */
/* ========================================================= */
.w-full { width: 100%; }
.h-full { height: 100%; }
.min-w-full {min-width: 100%;}
.min-h-screen { min-height: 100vh; }
.max-w-full { max-width: 100%; }
.max-w-md { max-width: 48rem; } /* 768px */


/* ========================================================= */
/* ðŸ“¦ ESPACIADO (MARGIN & PADDING) */
/* Escala: 0=0, 1=0.5rem (8px), 2=1rem (16px), 3=1.5rem (24px), 
		   4=2rem (32px), 5=2.5rem (40px), 6=3rem (48px)
*/
/* ========================================================= */

/* GAP */
.gap-0 { gap: 0; }
.gap-1 { gap: 0.5rem; }
.gap-2 { gap: 1rem; }
.gap-3 { gap: 1.5rem; }
.gap-4 { gap: 2rem; }
.gap-5 { gap: 2.5rem; }
.gap-6 { gap: 3rem; }

/* GAP */
.row-gap-0 { row-gap: 0; }
.row-gap-1 { row-gap: 0.5rem; }
.row-gap-2 { row-gap: 1rem; }
.row-gap-3 { row-gap: 1.5rem; }
.row-gap-4 { row-gap: 2rem; }
.row-gap-5 { row-gap: 2.5rem; }
.row-gap-6 { row-gap: 3rem; }

/* ========================================================= */

/* MARGIN GENERAL Y AUTO */
.m-0 { margin: 0; }
.m-auto { margin: auto; }
.mx-auto { margin-left: auto; margin-right: auto; }
.m-1 { margin: 0.5rem; }
.m-2 { margin: 1rem; }
.m-4 { margin: 2rem; }

/* MARGIN POR EJE (X e Y) */
.mx-0 { margin-left: 0; margin-right: 0; }
.my-0 { margin-top: 0; margin-bottom: 0; }
.mx-1 { margin-left: 0.5rem; margin-right: 0.5rem; }
.my-1 { margin-top: 0.5rem; margin-bottom: 0.5rem; }
.mx-2 { margin-left: 1rem; margin-right: 1rem; }
.my-2 { margin-top: 1rem; margin-bottom: 1rem; }
.mx-4 { margin-left: 2rem; margin-right: 2rem; }
.my-4 { margin-top: 2rem; margin-bottom: 2rem; }
.my-6 { margin-top: 3rem; margin-bottom: 3rem; }

/* MARGIN INDIVIDUAL (mt, mb, ml, mr) */
.mt-0 { margin-top: 0; }
.mt-1 { margin-top: 0.5rem; }
.mt-2 { margin-top: 1rem; }
.mt-3 { margin-top: 1.5rem; }
.mt-4 { margin-top: 2rem; }
.mt-5 { margin-top: 2.5rem; }
.mt-6 { margin-top: 3rem; }

.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: 0.5rem; }
.mb-2 { margin-bottom: 1rem; }
.mb-3 { margin-bottom: 1.5rem; }
.mb-4 { margin-bottom: 2rem; }
.mb-5 { margin-bottom: 2.5rem; }
.mb-6 { margin-bottom: 3rem; }

.ml-0 { margin-left: 0; }
.ml-1 { margin-left: 0.5rem; }
.ml-2 { margin-left: 1rem; }
.ml-3 { margin-left: 1.5rem; }
.ml-4 { margin-left: 2rem; }
.ml-5 { margin-left: 2.5rem; }
.ml-6 { margin-left: 3rem; }

.mr-0 { margin-right: 0; }
.mr-1 { margin-right: 0.5rem; }
.mr-2 { margin-right: 1rem; }
.mr-3 { margin-right: 1.5rem; }
.mr-4 { margin-right: 2rem; }
.mr-5 { margin-right: 2.5rem; }
.mr-6 { margin-right: 3rem; }


/* PADDING GENERAL */
.p-0 { padding: 0; }
.p-1 { padding: 0.5rem; }
.p-2 { padding: 1rem; }
.p-4 { padding: 2rem; }

/* PADDING POR EJE (X e Y) */
.px-0 { padding-left: 0; padding-right: 0; }
.py-0 { padding-top: 0; padding-bottom: 0; }
.px-1 { padding-left: 0.5rem; padding-right: 0.5rem; }
.py-1 { padding-top: 0.5rem; padding-bottom: 0.5rem; }
.px-2 { padding-left: 1rem; padding-right: 1rem; }
.py-2 { padding-top: 1rem; padding-bottom: 1rem; }
.px-4 { padding-left: 2rem; padding-right: 2rem; }
.py-4 { padding-top: 2rem; padding-bottom: 2rem; }
.py-6 { padding-top: 3rem; padding-bottom: 3rem; }

/* PADDING INDIVIDUAL (pt, pb, pl, pr) */
.pt-0 { padding-top: 0; }
.pt-1 { padding-top: 0.5rem; }
.pt-2 { padding-top: 1rem; }
.pt-3 { padding-top: 1.5rem; }
.pt-4 { padding-top: 2rem; }
.pt-5 { padding-top: 2.5rem; }
.pt-6 { padding-top: 3rem; }

.pb-0 { padding-bottom: 0; }
.pb-1 { padding-bottom: 0.5rem; }
.pb-2 { padding-bottom: 1rem; }
.pb-3 { padding-bottom: 1.5rem; }
.pb-4 { padding-bottom: 2rem; }
.pb-5 { padding-bottom: 2.5rem; }
.pb-6 { padding-bottom: 3rem; }

.pl-0 { padding-left: 0; }
.pl-1 { padding-left: 0.5rem; }
.pl-2 { padding-left: 1rem; }
.pl-3 { padding-left: 1.5rem; }
.pl-4 { padding-left: 2rem; }
.pl-5 { padding-left: 2.5rem; }
.pl-6 { padding-left: 3rem; }

.pr-0 { padding-right: 0; }
.pr-1 { padding-right: 0.5rem; }
.pr-2 { padding-right: 1rem; }
.pr-3 { padding-right: 1.5rem; }
.pr-4 { padding-right: 2rem; }
.pr-5 { padding-right: 2.5rem; }
.pr-6 { padding-right: 3rem; }

/* ========================================================= */

/* TipografÃ­a */
.text-center { text-align: center; }
.font-bold { font-weight: 700; }
.font-w-400 {font-weight: 400;}
.font-w-500 {font-weight: 500;}
.font-w-600 {font-weight: 600;}
.font-w-700 {font-weight: 700;}
.font-w-800 {font-weight: 800;}
.font-s-1rem {font-size: 1rem;}

/* ========================================================= */

.t-d-none {text-decoration: none!important;}

/* Transiciones */
.transistion-1 { transition: transform 0.3s ease;}

/* =====================
   COLORS
   ===================== */

.bg-black {background: var(--color-black);}
.text-white {color: var(--color-white);}


.noticias-section {

}

.noticias-container {
	position: relative;

}

.noticias-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 15px;
}

.noticias-title {
	margin: 0;
	color: #373737;
	font-family: "Source Sans 3";
	font-size: 30px;
	font-style: normal;
	font-weight: 600;
	line-height: normal;
}

.noticias-section .ver-todas {
	display: flex;
	align-items: center;
	gap: 8px;
	text-decoration: none;
	transition: all 0.3s 
ease;
	color: #324878;
	text-align: right;
	font-family: "Source Sans 3";
	font-size: 18px;
	font-style: normal;
	font-weight: 600;
	line-height: normal;
}

.noticias-section .ver-todas:hover {
text-decoration: none;
}

.noticias-section .carousel-wrapper {
	position: relative;

}

.noticias-section .carousel-track-container {
	overflow: hidden;
}

.noticias-section .carousel-track {
	display: flex;
	gap: 24px;
	transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.noticias-section .noticia-card {
	width: calc(50% - 12px);
	flex-shrink: 0;
}

.noticias-section .noticia-link {
	display: block;
	text-decoration: none;
	border-radius: 15px;
	overflow: hidden;
	transition: all 0.4s 
ease;
	height: 100%;
	margin-bottom: 8px;
}
.noticias-section .noticia-link:hover {
	text-decoration: none;

}

.noticias-section .noticia-imagen {
	position: relative;
	width: 100%;
	overflow: hidden;
	aspect-ratio: 573 / 380;
}

.noticia-placeholder {
	background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
}

.noticias-section .noticia-imagen img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
}

.noticia-link:hover .noticia-imagen img {

}

.noticias-section .noticia-overlay {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: auto;
	background: rgba(39, 86, 138, 0.60);
}

.noticias-section .noticia-contenido {
	padding: 20px;
	border-radius: 0 0 15px 15px;
	background: #F9F9F9;
	box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
}

.noticias-section .noticia-titulo {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	color: #FFF;
	font-family: Roboto;
	font-size: 19px;
	font-style: normal;
	font-weight: 600;
	line-height: 22px;
	margin: 20px;
}

.noticias-section .noticia-extracto {
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	color: #555;
	font-family: Roboto;
	font-size: 17px;
	font-style: normal;
	font-weight: 300;
	line-height: 22px;
}

.servicios-grid-botones .carousel-nav, .anuncios-section .carousel-nav, .noticias-section .carousel-nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 30px;
	height: 30px;
	padding: 0;
	/* border-radius: 50%; */
	background: transparent;
	border: none;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	z-index: 10;
	/* box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12); */
	transition: all 0.3s 
ease;
	color: #324878;
}

.noticias-section .carousel-nav:hover {
	
}
.servicios-grid-botones .carousel-nav:focus, .anuncios-section .carousel-nav:focus, .noticias-section .carousel-nav:focus {background: none;}
.servicios-grid-botones .carousel-nav.prev, .anuncios-section .carousel-nav.prev, .noticias-section .carousel-nav.prev {
	left: 0px;
}

.servicios-grid-botones .carousel-nav.next, .anuncios-section .carousel-nav.next, .noticias-section .carousel-nav.next {
	right: 0px;
}

.anuncios-section .carousel-indicators, .noticias-section .carousel-indicators {
	display: flex;
	justify-content: center;
	gap: 10px;
	position: relative;
	left: inherit;
	bottom: inherit;
	top: inherit;
	width: inherit;
	margin: 22px 0 0 0;
	right: inherit;
}

.anuncios-section .indicator-dot, .noticias-section .indicator-dot {
	width: 30px;
	height: 8px;
	border-radius: 3px;
	background: #c7b42e;
	border: none;
	cursor: pointer;
	padding: 0;
	opacity: 0.4;
	transition: all 0.3s 
ease;
}

.avisos-section .aviso-link {
    
    transition: background-color 0.3s ease, color 0.3s ease;
}

.avisos-section .aviso-link:hover {
    background-color: #c7b42e;
    color: #25458c;
}

.avisos-section .aviso-title:hover {
	color: black;
}

.anuncios-section .indicator-dot:hover, .noticias-section .indicator-dot:hover {
	opacity: 0.6;
}

.anuncios-section .indicator-dot.active, .noticias-section .indicator-dot.active {
	width: 30px;
	border-radius: 3px;
	height: 8px;
	opacity: 1;
}

@media (max-width: 1024px) {
	.noticia-card {
		min-width: calc(100% - 0px);
	}
	
	.carousel-wrapper {
		padding: 0 50px;
	}
}

@media (max-width: 768px) {
	
	
	
	
	.noticias-title {
		font-size: 2rem;
	}
	
	.carousel-wrapper {
		padding: 0 40px;
	}
	
	.carousel-nav {
		width: 40px;
		height: 40px;
	}
	
	.carousel-nav svg {
		width: 24px;
		height: 24px;
	}
}

@media (max-width: 480px) {
	.carousel-wrapper {
		padding: 0 35px;
	}
	
	.noticia-contenido {
		padding: 20px;
	}
	
	.noticia-titulo {
		font-size: 1.15rem;
	}
	
	.noticia-extracto {
		font-size: 0.95rem;
	}
}

.no-noticias {
	text-align: center;
	padding: 60px 20px;
	color: #999;
	font-size: 1.1rem;
}

/* SecciÃ³n de Avisos con Tabs */
.avisos-section {

}

.avisos-container {
	position: relative;
}

/* Tabs Header */
.tabs-header {
	display: flex;
	align-items: center;
	gap: 15px;
	margin-bottom: 15px;
	white-space: nowrap;
	justify-content: center;
}

.tab-btn {
	padding: 1.1rem 2.5rem;
	font-size: 1.4rem;
	font-weight: 400;
	font-family: "Source Sans 3";
	border: none;
	border-radius: 18px;
	background: #EEEEEE;
	line-height: 1em;
	color: #373737;
	cursor: pointer;
	transition: all 0.3s ease;
	white-space: normal;
	word-wrap: break-word;
}

.tab-btn:hover {
	opacity: 0.8;
}

.tab-btn.active {
	background: rgba(199, 180, 46, 0.9);
	color: #fff;
	font-weight: 700;
}

.ver-todos-avisos {
	display: flex;
	align-items: center;
	gap: 8px;
	text-decoration: none;
	transition: all 0.3s 
ease;
	margin-left: auto;
	color: #324878;
	text-align: right;
	font-family: "Source Sans 3";
	font-size: 18px;
	font-style: normal;
	font-weight: 600;
	line-height: normal;
	justify-content: right;
	margin-bottom: 10px;
}

.ver-todos-avisos:hover {
	text-decoration: none;
}

/* Tab Content */
.tab-content {
	display: none;
}

.tab-content.active {
	display: block;
}

/* Carousel */
.avisos-section .carousel-wrapper {
	position: relative;
}

.avisos-section .carousel-track-container {
	overflow: hidden;
}

.avisos-section .carousel-track {
	display: flex;
	gap: 20px;
	transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.avisos-section .aviso-card {
	width: calc(33.333% - 14px);
	flex-shrink: 0;
	margin: 8px 0;
}

.avisos-section .aviso-link {
	display: block;
	padding: 28px 26px;
	background: #fff;
	border-radius: 12px;
	text-decoration: none;
	box-shadow: 0 2px 12px rgba(0,0,0,0.08);
	transition: all 0.3s ease;
	height: 100%;
	min-height: 194px;
	border-radius: 5px;
	border: 2px solid #EEE;
	background: #F9F9F9;
	box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
}

.avisos-section .aviso-link:hover {
	/* transform: translateY(-6px); */
	/* box-shadow: 0 8px 24px rgba(0,0,0,0.12); */
	text-decoration: none;
}

.avisos-section .aviso-title {
	font-size: 17px;
	font-weight: 600;
	line-height: 1.5;
	font-family: Roboto;
	margin: 0 0 16px 0;
	display: -webkit-box;
	transition: color 0.3s ease;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	font-family: "Source Sans 3";
	font-size: 17px;
	font-style: normal;
	font-weight: 400;
	line-height: normal;
}

.avisos-section .aviso-date {
	font-size: 15px;
	color: #888;
	font-style: italic;
	font-family: Roboto;
	margin: 0;
	color: #555;
	font-family: "Source Sans 3";
	font-size: 17px;
	font-style: italic;
	font-weight: 500;
	line-height: normal;
}

/* Carousel Arrows */
.avisos-section .carousel-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 30px;
	height: 30px;
	padding: 0;
	border: none;
	display: flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	cursor: pointer;
	z-index: 10;
	transition: all 0.3s ease;
	color: #324878;
}

.avisos-section .carousel-arrow:hover {
}

.avisos-section .carousel-arrow:focus {
	background: none;
}

.avisos-section .carousel-arrow.prev {
	left: 0px;
}

.avisos-section .carousel-arrow.next {
	right: 0px;
}

/* Carousel Dots */
.avisos-section .carousel-dots {
	display: flex;
	justify-content: center;
	gap: 10px;
	position: relative;
	left: inherit;
	bottom: inherit;
	top: inherit;
	width: inherit;
	margin: 22px 0 0 0;
	right: inherit;
}

.avisos-section .carousel-dot {
	width: 30px;
	height: 8px;
	border-radius: 3px;
	background: #c7b42e;
	opacity: 0.4;
	border: none;
	cursor: pointer;
	padding: 0;
	transition: all 0.3s ease;
}

.avisos-section .carousel-dot:hover {
	opacity: 0.6;
}

.avisos-section .carousel-dot.active {
	width: 30px;
	border-radius: 3px;
	height: 8px;
	opacity: 1;
}

.no-avisos {
	text-align: center;
	padding: 60px 20px;
	color: #999;
	font-size: 1.1rem;
}

.cifras_mapa-section {
	position: relative;
	overflow: hidden;
	display: block;
	background: #F9F9F9;
	box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
	padding: 1.5rem;
	margin-bottom: 40px;
	border: 2px solid rgba(238, 238, 238, 1);
}
.cifras_mapa-container {}
.cifras-banner-widget {
	width: 436px;
	position: relative;
	height: auto;
	border-radius: 15px;
	max-width: 100%;
	overflow: hidden;
}
.cifras-banner-widget:before {
	content: "";
	position: absolute;
background: linear-gradient(180deg, rgba(222, 232, 255, 0.4) 0%, rgba(12, 19, 35, 0.4) 83.65%);
	width: 100%;
	height: 100%;
	z-index: 1;
	left: 0;
	top: 0;
}
.cifras-banner-widget .cont-banner {
	position: relative;
	z-index: 2;
	padding: 2rem;
	text-align: center;
	color: #fff;
	line-height: 1em;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.5rem;
}
.cifras-banner-widget .cont-banner h4 {
	font-weight: 600;
	line-height: 1;
	margin: 0;
	color: var(--color-white);
}
.cifras-banner-widget .cont-banner span {
	font-weight: 500;
	font-size: 16px;
	line-height: 1em;
}
.cifras-banner-widget .cont-banner img {
	max-width: 90%;
	height: auto;
}
.mapa-territorio-widget {
	flex: auto;
	display: flex;
	flex-direction: column;
	gap: 1rem;
	justify-content: space-between;
}
.btn_titulo {
	background: rgba(39, 86, 138, 0.9);
	color: var(--color-white);
	font-weight: 500;
	padding: 1rem 2.5rem;
	font-size: 22px;
	font-family: "Source Sans 3";
	border: none;
	border-radius: 15px;
	line-height: 1em;
	text-align: center;
	}
.mapa-embed-home {
	background: #d8d8d8;
	width: 100%;
	height: 100%;
	overflow: hidden;
	border: 1px solid rgba(85, 85, 85, 0.7);
}




/* Responsive */
@media (max-width: 1024px) {
	.avisos-section .aviso-card {
		width: 100%;
	}
}

.main-menu-mobile {
        display: none;
    }




@media (max-width: 480px) {
	
	.avisos-section .aviso-link {
		padding: 22px 20px;
		min-height: 140px;
	}
	
	.avisos-section .aviso-title {
		font-size: 16px;
	}
}



@media screen and (max-width: 767px) {
    
    .main-menu-mobile {
        display: block;
    }
    #header_new {
        z-index: 99999;
    }
    
}

.header_main {	width: 100%;
	display: block;
	padding: 1rem 0;
}
#header_new {
	width: 100%;
	position: relative;
	background: #21345E;
	margin: auto;
	display: block;
	line-height: 1em;
	color: #fff;
	font-family: "Source Sans 3";
	position: relative;
	z-index: 33;
}
#header_new.header-scrolling {
  position: sticky;
  top: 0;
}
#header_new.header-scrolling .header_main {
    padding: .7rem 0;
}
#header_new .logotipo img,
#header_new .custom-search-form,
#header_new .social_iconos a,
#header_new  #main-menu_new > ul > li a{
    transition: all 0.3s ease;
}
#header_new.header-scrolling .logotipo img {
    width: auto;
    height: 45px;
}
#header_new.header-scrolling .custom-search-form {
    height: 35px;
}
#header_new.header-scrolling .custom-search-input {
    font-size: 16px;
}
#header_new.header-scrolling .social_iconos a {
    width: 32px;
    height: 32px;
    font-size: 1.2rem;
}
#header_new.header-scrolling .header_bottom {
    padding: .5rem 0;
}
#header_new.header-scrolling #main-menu_new ul li ul {
    margin-top: 8px;
}
#header_new.header-scrolling #main-menu_new > ul > li > a {
    font-size: .75em;
    padding: .2em .55em;
}
#header_new.header-scrolling #main-menu_new > ul > li.menu-item-304 > a {
    padding-right: 1.5em;
}
#header_new.header-scrolling #main-menu_new ul li.menu-item-has-children>a:before {
    right: 5px;
    margin-top: -7px;
}




/* === BUSCADOR PERSONALIZADO HEADER === */
#header_new .custom-search-form {
  position: relative;
  display: inline-flex;
  align-items: center;
  background-color: #fff;
  border-radius: 20px;
  padding: 4px 15px;
  width: 300px;
  height: 44px;
}

#header_new .custom-search-input {
  border: none!important;
  outline: none;
  background: transparent;
  color: rgba(0, 91, 103, 0.7);
  font-size: 18px;
  width: 100%!important;
  padding-right: 25px;
  height: inherit;
  font-weight: 400;
  line-height: 150%;
  margin: inherit;
}

#header_new .custom-search-input::placeholder {
  color: rgba(0, 91, 103, 0.7); /* color placeholder similar al que se ve en la captura */
}

#header_new .custom-search-button {
  position: absolute;
  right: 15px;
  background: none!important;
  border: none!important;
  cursor: pointer;
  color: rgba(55, 55, 55, 1); /* ícono azul oscuro */
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0!important;
}

#header_new .custom-search-button:hover {
  color: #000;
}

#header_new .icon-search {
  pointer-events: none;
}
#header_new .social_iconos a {
	background: #324878;
	border-radius: 50%;
	width: 44px;
	height: 44px;
	padding: 0;
	border: 0;
	display: flex;
	align-items: center;
    justify-content: center;
    font-size: 1.4rem;
	color: #fff;
}
#header_new .social_iconos a:hover {
    text-decoration: none;
}


.header_bottom {
	background: #324878;
	width: 100%;
	display: block;
	padding: 0.7rem 0;
}
body:not(.menu-sandwich) .header_bottom #main-menu > ul {
	margin: 0;
	justify-content: center;
	display: flex;
	gap: 3rem;
}
body:not(.menu-sandwich) .header_bottom #main-menu > ul > li {
	font-size: 1.3rem;
	font-weight: 500;
}
body:not(.menu-sandwich) .header_bottom #main-menu > ul > li a {
	font-family: "Source Sans 3";
}


.navbar-toggle_new {
	position: relative;
	margin-right: 10px;
	margin-top: -4px;
	background-color: transparent;
	background-image: none;
	border: 1px solid transparent;
	border-radius: 4px;
	border: 0;
}
#main-menu {
    background-color: #324878;
    padding: 40px 20px 0 20px;
}
#main-menu .navbar-nav {
    margin-bottom: 30px;
}
#main-menu .custom-search-form {
    width: 100%;
}
#main-menu .social_iconos {
    margin-top: 30px;
}
#main-menu .social_iconos a {
    background-color: #21345E;
}
button:focus {background: none;}
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border-width: 0;
}
.navbar-toggle_new .icon-bar {
	width: 20px;
	border-radius: 0;
	background-color: #fff;
	height: 3px;
	display: block;
	margin-top: 4px;
}
#footer {
	background-color: #003E67;
	color: #fff;
	font-family: "Source Sans 3";
}
#footer a {border: none!important;}
#footer a:hover {border: none!important;}
.footer-bottom-new {
	background: #003152;
}
#footer .copyright_new {
	text-align: center;
	line-height: 1.2rem;
	font-size: 1rem;
	font-weight: 500;
}
.btn_boletin_recibe {
	border-radius: 10px;
	background: #48719F;
	box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
	padding: 15px;
	text-align: center;
}

.btn_boletin_recibe span {
	color: #FFF;
	font-family: "Source Sans 3";
	font-size: 20px;
	font-style: normal;
	font-weight: 500;
	line-height: 29px;
}
#footer .social_iconos a {
	display: block;
	background: #003152;
	border-radius: 50%;
	width: 44px;
	height: 44px;
	padding: 0;
	border: 0;
	display: flex;
	align-items: center;
    justify-content: center;
    font-size: 1.4rem;
	color: #fff;
}
#footer h3.widget-title {
	font-size: 1.2rem;
	font-weight: bold;
	color: #fff;
	line-height: 1.65rem;
	margin-bottom: 0.5rem;
	font-family: "Source Sans 3";
}
#footer .footer-menu-uno {}
#footer .footer-menu-uno ul {margin: 0;}
#footer .footer-menu-uno ul li {}
#footer .footer-menu-uno ul li a {
	color: #fff;
	font-size: 1rem;
	font-weight: normal;
	line-height: 1.65rem;
	font-family: "Source Sans 3";
	text-decoration: none;
}
#footer .footer-menu-uno ul li a:hover {}


.contact-box {
  color: #ffffff;
  font-family: "Source Sans 3";
}

.contact-item {margin-bottom: 0.5rem;}

.contact-item:last-child {
  margin-bottom: 0;
}

.contact-label {
  display: flex;
  align-items: baseline;
  color: #fff;
  line-height: 1.3rem;
}
#footer .contact-label,
#footer .contact-label i,
#footer .contact-value,
.info-bar-rect .contact-label {
    color: #fff!important;
}

.contact-label i {
  margin-right: 6px;
  color: #ffffff;
  line-height: 1rem;
}

.contact-value {

  font-weight: 400;
  line-height: 1rem;
  color: #FFFFFFCC;
}

.contact-value a {
  color: #e6eef4;
  text-decoration: none;
}

.contact-value a:hover {
  text-decoration: underline;
}


#footer iframe.mapa_footer {width: 100%;height: 270px;}

.hide-desktop {
    display: none!important;
}
.manual-us-label {
	position: absolute;
	bottom: 0;
	width: 100%;
	z-index: 6;
	color: #fff;
	line-height: 1em;
	background: #294787;
	font-weight: 600;
	font-size: 16px;
	padding: 10px;
}
.manual-us-label a {color: var(--color-white);}
@media (max-width:991px) {
	.flex-col-md { flex-direction: column; }
	.gap-1-md { gap: 0.5rem; }
	.gap-2-md { gap: 1rem; }
	.gap-4-md { gap: 2rem; }
	.p-0-md {padding: 0;}
	.py-1-md { padding-top: 0.5rem; padding-bottom: 0.5rem; }
	.m-auto-md { margin: auto; }
	.overflow-h-md { overflow: hidden; }
	.flex-w-full-md {flex: 100%;}
	.flex-w-none-md {flex: none;}
	.justify-center-md {justify-content: center;}
	.font-s-14px-md {font-size: 14px;}
	.d-none-md {display: none!important;}
	.d-block-md {display: block;}
	.w-50px-md {width: 50px;}
	.servicios-grid-botones .carousel-nav, .anuncios-section .carousel-nav, .noticias-section .carousel-nav, .avisos-section .carousel-arrow {width: 20px;height: 20px;padding: 0;}
	.servicios-grid-botones .carousel-nav.prev, .anuncios-section .carousel-nav.prev, .noticias-section .carousel-nav.prev, .avisos-section .carousel-arrow.prev { left: 0; }
	.servicios-grid-botones .carousel-nav.next, .anuncios-section .carousel-nav.next, .noticias-section .carousel-nav.next, .avisos-section .carousel-arrow.next { right: 0; }
	.carousel-wrapper { padding: 0 24px; }
	.titulo-slider-home {font-size: 2rem;}
	.isotipo-slider-home {max-width: 13%;min-width: 80px; max-height: 120px;}
	#main-menu_new {
		overflow-y: auto;
		position: fixed;
		top: 0;
		bottom: 0;
		left: 100%;
		z-index: 9999;
		height: 100%;
		background-color: #0F2044;
		padding: 40px 25px 0 25px;
		width: 270px;
		-webkit-transition: margin .8s ease;
		-o-transition: margin .8s ease;
		transition: margin .8s ease;
	}
	#main-menu_new.open {
		margin-left: -270px;
	}
	#main-menu_new .button-close {width: 20px;height: 20px;cursor: pointer;margin-bottom: 15px;color: #fff;margin-top: 10px;line-height: 1em;font-size: 1rem;}
	#main-menu_new>ul {
		margin: 0;
		float: none;
		top: 0;
		position: relative;
	}
	#main-menu_new>ul>li {
		font-size: 1.1rem;
		width: 100%;
		display: block;
		position: relative;
		float: none;
		font-weight: 500;
	}
	#main-menu_new>ul>li>a {
		padding: 10px 0;
		color: #fff;
		line-height: 1;
		display: block;
		position: relative;
		cursor: pointer;
		background: transparent;
	}
	#main-menu_new ul li.menu-item-has-children>a {
		margin-right: 56px;
	}
	#main-menu_new .dropdown-toggle {
		position: absolute;
		right: 0;
		top: 0;
		width: 36px;
		line-height: 1rem;
		border: none;
		background: 0 0;
		-webkit-box-shadow: none;
		box-shadow: none;
		outline: 0;
		font-family: 'Visual Composer Starter Font';
		font-size: .64em;
		-webkit-transition: -webkit-transform .3s ease;
		transition: -webkit-transform .3s ease;
		-o-transition: transform .3s ease;
		transition: transform .3s ease;
		color: #fff;
		padding: 17px 0 0px 0;
		padding-top: 12px;
	}
	#main-menu_new .dropdown-toggle.open {
		-webkit-transform: rotate(180deg);
		-ms-transform: rotate(180deg);
		transform: rotate(180deg);
		padding-bottom: 11px !important;
	}
	#main-menu_new>ul>li>a:hover {color: #ccc; text-decoration: none;}
	#main-menu_new ul li ul {
		display: none;
		padding: 5px 0;
	}
	#main-menu_new ul li ul li {font-size: 0.9rem;line-height: 1.1rem;text-decoration: none;font-weight: 400;}
	#main-menu_new ul li ul li a {
		padding: 4px 0;
		display: block;
		color: #ccc;
	}
	#main-menu_new ul li ul li a:hover {text-decoration: none;	opacity: 0.6;}
	.tab-btn {
	padding: 1rem 2rem;
	font-size: 1.1rem;}
	.ver-todos-avisos {
		width: 100%;
		justify-content: center;
		margin-left: 0;
		font-size: 16px;
		line-height: 1em;
		text-align: center;
	}
	.noticias-header {
		flex-direction: column;
		align-items: center;
		gap: 0px;
	}
	.noticias-section .ver-todas {
		text-align: center;
		justify-content: center;
		width: 100%;
		line-height: 1em;
		font-size: 16px;
	}
}
@media (max-width:767px) {
	.titulo-slider-home {font-size: 1.7rem;}
	.tabs-header {gap: 10px;}
	.tab-btn {
		padding: 0.8rem 1rem;
		font-size: .85rem;
		flex: 0;
		border-radius: 12px;
		white-space: inherit;
	}
	.servicios-grid-botones .caluga-icon-home {	width: calc(100% / 2 - 7px);}
	.flex-col-sm { flex-direction: column; }
	.gap-2-sm {gap: 1rem;}
	.w-full-sm {width: 100%;}
	.m-0-sm {margin: 0;}
}

@media (max-width:580px) {
	.slides {aspect-ratio: 5 / 2;}
	.titulo-slider-home {font-size: 1.4rem;}
}

@media (max-width:480px) {
	.tabs-header {gap: 8px;}
	.tab-btn {
		padding: .8rem;
		font-size: .9rem;
		flex: 1;
	}
	.w-full-xs {width: 100%;}
	.servicios-grid-botones .caluga-icon-home {width: 100%;}
}
@media (max-width:425px) {
	.titulo-slider-home {font-size: 1.2rem;}
}

@media (min-width:992px) {
	  #main-menu_new {
		  position: static;
		  width: auto;
		  background: 0 0;
		  padding: 0;
		  overflow-y: inherit;
	  }
	#main-menu_new > ul {
			margin: 0;
			justify-content: center;
			display: flex;
			gap: 3rem;
			float: none;
		}
	#main-menu_new > ul > li {
		font-size: 1.3rem;
		font-weight: 500;
		float: none;
	}
	#main-menu_new > ul > li a {
		font-family: "Source Sans 3";
		color: #ffffff;
		font-size: .875em;
		padding: .55em;
		line-height: 1em;
		text-decoration: none;
		background: transparent;
	}
	#main-menu_new ul li.menu-item-has-children>a {	padding-right: 2.05em;}
	#main-menu_new ul li.menu-item-has-children>a:before {
		content: '\71';
		top: 50%;
		right: 1.5em;
		margin-top: -10px;
		font-family: 'Visual Composer Starter Font';
		font-size: .55em;
		position: absolute;
		transform: rotate(0);
	}
	#main-menu_new ul li ul {
			transition: all .3s ease;
			display: block !important;
			padding: 0;
			visibility: hidden;
			opacity: 0;
			z-index: 100;
			position: absolute;
			right: 100%;
			top: 100%;
			width: 13.75rem;
			background-color: #1b3367;
			box-shadow: 0 0 5px rgba(0, 0, 0, .2);
			left: 0;
			margin-top: 10px;
		}
	 #main-menu_new ul li:hover>ul {
			visibility: visible;
			opacity: 1;
		}
	 #main-menu_new ul li ul li {
	    width: 100%;
		position: relative;
		padding: 0;
	}
	#main-menu_new ul li ul li a {
		padding: 10px 18px;
		line-height: 1.3;
		font-size: 14px;
		display: block;
	}
	#main-menu_new .button-close {
		display: none;
	}
	.navbar-toggle_new {
		display: none !important;
	}
	img.isotipo-slider-home {
		/*width: 120px;
		max-width: 13%;*/
		min-width: 80px;
	}
	.sgdc {margin-right: 0px;}
}

@media (min-width: 992px) and (max-width: 1280px) {
	.carousel-wrapper {
		padding: 0 30px;
	}
	.anuncios-section .carousel-nav.prev, .noticias-section .carousel-nav.prev, .avisos-section .carousel-arrow.prev {
		left: 0px;
	}
	.anuncios-section .carousel-nav.next, .noticias-section .carousel-nav.next, .avisos-section .carousel-arrow.next {
		right: 0px;
	}
}

@media (min-width: 1200px) and (max-width: 1280px) {
	.servicios-grid-botones .caluga-icon-home {
		width: calc(214px / 1 - 5px);
	}
}
@media (min-width: 1281px) {

	.servicios-grid-botones .carousel-nav.prev, .anuncios-section .carousel-nav.prev, .noticias-section .carousel-nav.prev, .avisos-section .carousel-arrow.prev {
		left: -30px;
	}
	.servicios-grid-botones .carousel-nav.next, .anuncios-section .carousel-nav.next, .noticias-section .carousel-nav.next, .avisos-section .carousel-arrow.next {
		right: -30px;
	}
	
	.servicios-grid-botones {
		margin-right: -30px;
		padding: 0px 30px;
	}
}

@media only screen and (max-width: 991px) {
    
    body #header_new .navbar-toggle,
    body #header_new .button-close {
        display: block !important;
    }
    .anuncio_slide a img {
        width: 100%;
        height: auto;
    }
    .cifras-banner-widget {
        width: 100%;
    }
    body #header_new #main-menu.main-menu-mobile {
        overflow-y: auto;
        position: fixed;
        top: 0;
        bottom: 0;
        left: 100%;
        z-index: 9999;
        height: 100%;
        background-color: #324878;
        padding: 40px 20px 0 20px;
        display: block
    }
    body #header_new #main-menu.main-menu-mobile.open {
        margin-left: -270px;
    }
    #main-menu .navbar-nav {
        width: 100%;
    }
    .navbar-nav > li {
        float: none;
    }
    .simple-banner {
        z-index: 2!important;
    }
    .hide-desktop {
        display: block!important;
    }
}



@media (max-width:767px) {
	
	#header_new {
	    z-index: 99999;
	}
	.anuncio_slide a img {
	    width: 100%;
	    height: auto;
	}
	#header_new.header-scrolling .header_bottom {
	    display: none;
	}
	.info-bar-rect {
	    z-index: 99;
	}
	.cifras-banner-widget {
	    width: 100%;
	}
	.cifras_mapa-section {
        padding: 20px!important;
    }
}








