@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

@font-face {
  font-family: Fontastique;
  src: url("assets/fontastique.ttf")
}


.b-example-divider {
	height: 3rem;
	background-color: rgba(0, 0, 0, .1);
	border: solid rgba(0, 0, 0, .15);
	border-width: 1px 0;
	box-shadow: inset 0 .5em 1.5em rgba(0, 0, 0, .1), inset 0 .125em .5em rgba(0, 0, 0, .15);
}

@media (min-width: 992px) {
	.rounded-lg-3 {
		border-radius: .3rem;
	}
}

body {
	font-family: 'Montserrat', sans-serif;
	color: #fff;
	background: rgb(82,2,102);
	background: linear-gradient(57deg, rgba(82,2,102,1) 0%, rgba(146,74,170,1) 100%);	
/*
	background-image: url("assets/images/back2.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: left bottom;
*/
	background-attachment: fixed;

}

/*---------- START OF TRANSITION AND ANIMATION -----------*/
section .topo {
	position: relative;
}

.confetes {
	width: 100vh;
	margin-left: 50%;
	z-index: 0;
	position: fixed;
	animation: changePositionConfetes 50s ease infinite;
}

@keyframes changePositionConfetes {
	0% {
		transform: translateX(0%);
	}

	25% {
		transform: translateX(50%);
		transform: translateY(50%);
	}

	50% {
		transform: translateX(100%);
		transform: scale(2);
	}

	100% {
		transform: translateX(0%);
		transform: translateY(0%);
	}
}

.confetes-reverso {
	width: 100vh;
	margin: auto;
	z-index: 0;
	position: fixed;
	animation: changePositionConfetesReverse 50s ease-in-out infinite reverse;
}

@keyframes changePositionConfetesReverse {
	0% {
		transform: translateY(-50%);
		transform: translateX(-50%);
	}

	25% {
		transform: translateY(-50%);
		transform: translateX(-50%);
	}

	50% {
		transform: translateY(-100%);
		transform: scale(3);
	}

	100% {
		transform: translateY(0%);
		transform: translateX(0%);
	}
}

.logo {
	animation: chegadaImpactante 2s ease;
}

@keyframes chegadaImpactante {
	0% {
		transform: translateX(0%);
		opacity: 0%;
	}

	25% {
		transform: translateX(3px) rotate(3deg) translateY(3px);
		transform: perspective(3px) translate(3px, 0, 3px) rotateY(3deg);
	}

	50% {
		transform: translateX(-3px) rotate(-3deg) translateY(-3px);
		transform: perspective(-3px) translate(-3px, 0, -3px) rotateY(-3deg);
	}

	100% {
		transform: translateY(0%);
		opacity: 100%;
	}
}

/*---------- END OF TRANSITION AND ANIMATION -----------*/

main p {
	font-size: 15pt;
	margin-bottom: 30px;
}

main p.obs {
	font-size: 13pt;
	margin-bottom: 40px;
	text-align: center;
}

.anil-ilha {
	text-align: center;
}

.topo {
	height: 900px;
	background: url("assets/images/top.jpg") no-repeat center right;
	background-size: cover;
	display: flex;
	align-items: center;
}

.img-carnaval {
	height: 600px;
	margin-left: 200px;
}

.img-logo {
	height: 120px;
	margin-left: 275px;
	margin-top: 40px;
}

.programacao {
	margin-top: 100px;
	margin-bottom: 100px;
	position: relative;
	z-index: 10;
}

h2 {
	font-size: 5rem;
	font-weight: 700;
	text-transform: uppercase;
	text-align: center;
	margin: 40px 0;
	letter-spacing: -2px;
	margin-bottom: 10px;
}

h2.local-prog {
	font-family: 'Fontastique', 'Montserrat', sans-serif;
	font-size: 3.3rem;
	font-weight: 500;
	text-transform: none;
	margin-top: 70px !important;
	color: #fbd257;
}

h3 {
	font-size: 24pt;
	color: #520266;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: -2px;
	text-align: center;
	background: #f2ce30;
	background-image: url("assets/images/back-h3b.jpg");
	background-repeat: no-repeat;
	background-position: top right;
	background-size: cover;
	transform: rotate(358deg);
	width: fit-content;
	padding: 3px 20px;
	margin: 0 auto;
	margin-bottom: 25px;
}

h3.h3-verde {
	background-image: url("assets/images/back-h3b-azul.jpg");
	color: #fff;
	background-color: #0a58ca;
	margin-bottom: 0;
}

h3.h3-roxo {
	background-image: url("assets/images/back-h3b-rosa.jpg");
	color: #fff;
	background-color: #8a0376;
}

.as-divs > .foto-artista {
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: flex-end;
	margin-bottom: 20px;
}

.as-divs > .foto-artista > img {
	width: 100%;
	max-width: 500px;
}

footer.footer-section {
	background-color: #1e2e7d;
	padding-top: 80px;
	padding-bottom: 80px;
}

.img-footer {
	width: 80%;
	max-width: 250px;
	height: fit-content;
}

@media (max-width: 1200px) {
	.img-carnaval {
		height: 600px;
		margin-left: 80px;
	}

	.img-logo {
		height: 120px;
		margin-left: 150px;
		margin-top: 40px;
	}
}

@media (max-width: 992px) {
	.img-carnaval {
		height: 500px;
		margin-left: 0;
	}

	.img-logo {
		height: 120px;
		margin-left: 50px;
		margin-top: 40px;
	}
}

@media (max-width: 768px) {
	h2 {
		font-size: 2.7rem;
	}
	
	h2.local-prog {
		font-size: 2.5rem;
		margin-top: 50px !important;
	}
		
	h3 {
		font-size: 20pt;
	}
	
	.as-divs {
		margin-top: 20px !important;
	}
	
	main p {
		font-size: 13pt;
		margin-bottom: 25px;
	}

	main p.obs {
		font-size: 11.5pt;
		margin-bottom: 20px;
	}

	.img-carnaval {
		height: 480px;
		margin-left: 0;
	}

	.img-logo {
		height: 120px;
		margin-left: 40px;
		margin-top: 40px;
	}

	.topo {
		background-position: -500px center;
	}
}

@media (max-width: 576px) {
	.img-carnaval {
		height: 480px;
		margin-left: 40px;
	}

	.img-logo {
		height: 120px;
		margin-left: 60px;
		margin-top: 40px;
	}

	.topo {
		background-position: -600px center;
	}
}


@media (max-width: 480px) {
	.img-carnaval {
		height: 280px;
		margin-left: 20px;
	}

	.img-logo {
		height: 80px;
		margin-left: 30px;
		margin-top: 40px;
	}

	.topo {
		height: 600px;
		background-position: -480px center;
	}
}

section .programacao {
	z-index: 10;
}

/* ------------ BOTÃO GO TO TOP ------------ */

button#gotop{
	position: fixed;
	right: 3%;
	bottom: 3%;
	opacity: 0;
	visibility: hidden;
	
	/*para melhor aparencia do botão*/
	font-family: sans-serif;
	font-size: 14pt;
	line-height: 0;
	color: #fff;
	background-color: #4db6ac;
	border: none;
	border-radius: 50px;
	box-shadow: black 0.1em 0.1em 0.1em;
	outline: none;
	cursor: pointer;
	padding: 20px 20px;
	margin: 0;
	z-index: 100;
}