/*-------------------------------------------------------------------
	Front page 
------------------------------------------------------------------*/

/* ---------------------------- Slider CSS ---------------------------- */
#slider-section {
	position: relative;
}

.front-slider-container {
	width: 100%;
	position: relative;
	overflow: hidden;
	min-height: 640px;
	height: 100vh;
	margin-left: auto;
	margin-right: auto;
}

#slider-section .front-slider-container>iframe,
#slider-section .front-slider-container>video {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translateX(-50%) translateY(-50%);
	transform: translateX(-50%) translateY(-50%);
	min-width: 100%;
	min-height: 100vh;
	/* min-height: 100%; */
	/* enable it if a min-height is also set for .front-slider-container */
	width: auto;
	height: auto;
	overflow: hidden;
	object-fit: fill;
	box-sizing: border-box;
}

/* https://codepen.io/desandro/pen/RNByrj */
#slider-section .front-slider-container>.main-carousel {
	position: absolute;
	width: 100% !important;
	/* min-width: 100%; */
	min-height: 100vh;
}

.carousel-cell {
	width: 100% !important;
	box-sizing: border-box;
	background: #222;
	min-height: 100vh;
}

.carousel-cell>img {
	display: block;
	width: 100% !important;
	height: 100%;
	min-height: 100vh;
	object-fit: fill;
}

#search {
	display: inline-block;
	width: auto;
	/* z-index: 3;
	top: 27%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%); */
}

.inner-hero-container {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	gap: 8rem;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 9999;
}

@media all and (max-width: 600px) {
	.carousel-cell>img {
		object-fit: cover;
	}

	#searchbar-container>button {
		width: 80px;
		font-size: 24px;
	}

	#searchbar-container>input {
		height: 40px;
	}

	#search {
		top: 50%;
	}
}

/* ---------------------------- Custom Announcement Section CSS ---------------------------- */
#promo-banner-container {
	display: flex;
	justify-content: center;
	min-height: 300px;
}

#promo-banner-container>img {
	max-height: 250px;
	height: 250px;
	width: auto;
	align-self: center;
}

#promo-banner-container>h3 {
	margin: auto 0;
	align-self: center;
	text-align: center;
	font-size: 18px;
	width: 45%;
}

#promo-banner-container>h3>span {
	display: block;
	font-weight: bold;
	margin-bottom: 20px;
}

#promo-banner-container:hover {
	text-decoration: none;
}

#promo-banner-container:hover>h3 {
	color: #0056b3;
}

@media all and (max-width: 1024px) {
	#promo-banner-container {
		flex-direction: column;
		padding: 60px 5px;
	}

	#promo-banner-container>h3 {
		width: 100%;
	}

	#promo-banner-container>img {
		max-width: 300px;
		align-self: center;
		margin-bottom: 20px;
	}
}

/* ---------------------------- Actions Section CSS ---------------------------- */
#actions-section {
	position: relative;
	background-color: #EEF1F9;
	width: 100%;
	min-height: 1px;
}

#wish-services-container {
	width: 100%;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 2rem;
}

#wish-services-container .wish-service {
	width: 370px;
	height: 270px;
	border-radius: 8px;
	opacity: .8;
}

#wish-services-container .wish-service:hover {
	opacity: 1;
}

#wish-services-container .wish-service .wish-service-title {
	text-align: center;
}

#wish-services-container .wish-service .wish-service-img {
	margin: 0 auto;
	text-align: center;
}

#wish-services-container .wish-service .wish-service-img img {
	max-width: 100%;
	height: 120px;
	width: auto;
	margin: 20px auto;
}

#wish-services-container .wish-service>a {
	padding: 20px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	width: 100%;
	height: 100%;
	transition: all 0.3s;
}

#wish-services-container .wish-service>a:hover {
	text-decoration: none;
	box-shadow: 1px 1px 2px 2px #969292;
	border-radius: 8px;
}

@media screen and (max-width:1527px) {
	#wish-services-container .wish-service {
		width: 280px !important;
		height: 180px !important;
	}

	#wish-services-container .wish-service .wish-service-img img {
		height: 80px !important;
		margin: 10px auto !important;
	}

	#wish-services-container .wish-service-title {
		font-size: 1em !important;
	}

}

#wish-services-container .wish-service-title {
	font-weight: bold;
	font-size: 1.2em;
}

#wish-services-container .wish-service-desc {
	text-align: center;
}

@media all and (max-width: 1024px) {
	#wish-services-container {
		position: relative !important;
		left: auto !important;
		transform: none !important;
		bottom: auto !important;
		flex-direction: column !important;
		align-items: center !important;
		gap: 0 !important;
	}

	#wish-services-container .wish-service {
		max-width: 100% !important;
		width: 100% !important;
		border-radius: 0 !important;
		opacity: 1 !important;
	}

	#wish-services-container .wish-service:not(:last-child) {
		margin-right: 0 !important;
	}
}


/* ---------------------------- Wish Section CSS ---------------------------- */

#wish-section {
	/* background-image: url(../images/bg.svg); */
	background-color: var(--main-site-color);
	background-repeat: no-repeat;
	background-position: center;
	width: 100%;
	height: 100%;
}

#wish-section .text-main {
	color: var(--white-text-color);
}

.wish-wrapper {
	height: 220px;
}

.wish-wrapper a {
	height: 100%;
}

.wish-wrapper a:hover {
	text-decoration: none;
}

.wish-inner {
	background: var(--white-text-color) 0% 0% no-repeat padding-box;
	/* border: var(--secondary-site-color) solid 1px; */
	-webkit-box-shadow: 0px 0px 5px #c1c1c033;
	box-shadow: 0px 0px 5px #c1c1c033;
	border-radius: 2px;
	opacity: 1;
	max-width: 100%;
	-webkit-transition: -webkit-box-shadow 0.3s;
	transition: -webkit-box-shadow 0.3s;
	-o-transition: box-shadow 0.3s;
	transition: box-shadow 0.3s;
	transition: box-shadow 0.3s, -webkit-box-shadow 0.3s;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	transition: all 0.2s;
}

.wish-inner:hover {
	-webkit-box-shadow: 0 0 11px rgba(33, 33, 33, 0.2);
	box-shadow: 0 0 11px rgba(33, 33, 33, 0.2);
	background-color: var(--main-site-color);
}

.wish-img svg {
	height: 120px;
	width: auto;
	margin: auto;
	fill: var(--main-site-color);
	transition: all 0.2s;
}

.wish-inner:hover .wish-img svg {
	fill: var(--secondary-site-color);
}

.wish-img {
	text-align: center;
	width: 30%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.wish-text {
	width: 70%;
	text-align: center;
	cursor: pointer;
}

.wish-title {
	color: var(--main-site-color);
	font-size: 18px;
	cursor: pointer;
	transition: all 0.2s;
}

.wish-hr {
	background-color: var(--main-site-color);
}

.wish-inner:hover .wish-hr {
	background-color: var(--white-text-color);
}

.wish-desc {
	color: var(--main-site-color);
	font-size: 15px;
	cursor: pointer;
	transition: all 0.2s;
}

.wish-inner:hover .wish-title,
.wish-inner:hover .wish-desc {
	color: var(--white-text-color);
}


/* ---------------------------- Services Section CSS ----------------------------*/
#services-section {
	background-color: #EEF1F9;
	padding-top: 5rem;
	padding-bottom: 5rem;
	/* min-height: 100vh; */
}

#crescent {
	display: inline-block;
	position: relative;
	bottom: 5px;
	left: 5px;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	box-shadow: inset 5px 0px #fff, inset 3px 0px 1px 2px #fff;
	padding: 5px;
	/* margin-right: 10px; */
	margin-bottom: -5px;
	transform: rotate(20deg);
}

#crescent span {
	display: inline-block;
	transform: rotate(-20deg);
}

.service-wrapper a {
	color: var(--white-text-color);
}

.service-wrapper:hover,
.service-wrapper:hover .service-inner>.service-description {
	/* color: #144589; */
	text-decoration: none;
}

/* https://codepen.io/dig-lopes/pen/XovjNL */
.service-wrapper {
	display: block;
	padding: 0.5em 0.8em;
	/* color: var(--main-site-color); */
	position: relative;
	text-decoration: none;
	/* font-size: 20px; */
	box-sizing: border-box;
	transition: all 0.35s ease;
}


/* ---------------------------- Ipiresies Section CSS ----------------------------*/

#ipiresies-section {
	box-shadow: inset 0 0 0 1000px rgba(58, 62, 112, 0.58);
	background-size: cover;
	padding-top: 5rem;
	padding-bottom: 5rem;
}

#ipiresies-login-button {
	width: 211px;
	height: 59px;
	background-color: #fff;
	color: #212529;
	border-radius: 9px;
	font-size: 20px;
	text-align: center;
	transition: all .4s ease;
}

#ipiresies-login-button:hover {
	transform: translateY(-5px)
}

/* ---------------------------- Contact Section Section CSS ----------------------------*/

a.social-link {
	color: var(--contact-section-color);
}

a.social-link:hover {
	color: var(--contact-section-color);
}

@media (max-width: 1024px) {
	.map-filters {
		left: 0;
		transform: translateY(-50%);
		padding: 2rem;
	}
}

@media (max-width: 400px) {
	.helper-heading>.container>.d-flex {
		min-height: 100px;
	}
}

#contact-section {
	background-color: var(--secondary-site-color);
	padding-bottom: 5rem;
	padding-top: 5rem;
}

#contact-section>* {
	color: var(--contact-section-color);
}

.contact-municipality,
.contact-mayor {
	display: flex;
	flex-direction: column;
}

.contact-mayor a,
.contact-municipality a {
	color: var(--contact-section-color);
}

.contact-mayor a:hover,
.contact-municipality a:hover {
	color: var(--contact-section-color);
	text-decoration: underline;
}

.contact-mayor img,
.contact-municipality img {
	object-fit: cover;
	max-width: 180px;
	min-height: 180px;
	height: auto;
	padding: 0;
}

.contact-flex {
	display: flex;
}

.contact-flex>div {
	display: flex;
	flex-direction: column;
	justify-content: center;
	width: 240px;
	height: 300px;
}

#mayor-image {
	height: 200px;
	align-self: center;
}

#mayor-details {
	height: 200px;
	align-self: center;
	display: flex;
	align-items: center;
}

#muni-image {
	height: 200px;
	align-self: center;
}

#muni-details {
	height: 200px;
	align-self: center;
	display: flex;
	align-items: center;
}

#mayor-send-message,
#mayor-send-idea,
#muni-send-request,
#muni-view-telephones {
	height: 100px;
	align-self: center;
}

#mayor-send-message>a,
#mayor-send-idea>a,
#muni-send-request>a,
#muni-view-telephones>a {
	display: block;
	border: 1px solid var(--white-text-color);
	border-radius: 4px;
	color: var(--white-text-color);
	width: 200px;
	padding: 10px;
	transition: all 0.2s;
}

#mayor-send-message>a:hover,
#mayor-send-idea>a:hover,
#muni-send-request>a:hover,
#muni-view-telephones>a:hover {
	border: 1px solid var(--main-site-color);
	color: var(--secondary-site-color);
	background-color: var(--white-text-color);
	text-decoration: unset;
}

section#user-manual-section {
	background-color: var(--section-user-manual-bg);
}

section#user-manual-section .section-inner-wrapper {
	gap: 3rem;
}

section#user-manual-section .section-inner-wrapper p {
	color: white;
	font-size: 20px;
	margin: 0 !important;
}

@media all and (max-width: 1024px) {
	.contact-flex {
		flex-direction: column;
	}

	.contact-flex>div,
	#mayor-image,
	#mayor-details,
	#muni-image,
	#muni-details,
	#mayor-send-message,
	#mayor-send-idea,
	#muni-send-request,
	#muni-view-telephones {
		height: auto;
	}

	#mayor-details,
	#muni-details {
		margin-top: 40px;
	}

	.contact-municipality {
		margin-top: 40px;
		margin-bottom: 40px;
	}

	#mayor-send-message,
	#mayor-send-idea,
	#muni-send-request,
	#muni-view-telephones {
		margin-top: 40px;
	}
}

@media all and (max-width: 768px) {
	#contact-section .container {
		margin: 0 auto;
	}

	#social-links {
		margin-bottom: 60px;
	}
}

@media screen and (max-width: 600px) {
	section#user-manual-section .section-inner-wrapper {
		flex-wrap: wrap;
	}

	section#user-manual-section .section-inner-wrapper p {
		text-align: center;
	}
}

.page-id-599 .navigation {
	display: none;
}


/* ---------------------------- Doc Validation Section CSS ---------------------------- */

section#doc-validation-section .section-title {
	color: #354353;
	margin-bottom: 0;
	font-size: 24px;
}

section#doc-validation-section .section-inner-wrapper {
	gap: 3rem;
}

.doc-validation-link {
	border: 1px solid #354354;
	border-radius: 12px;
	color: #354353;
	font-size: 20px;
	padding: 1rem 2rem;
	transition: all ease-in-out 0.3s;
	text-decoration: none !important;
}

.doc-validation-link:hover {
	background: #354353;
	color: #FFFFFF;
}