*{margin:0; padding:0;}
*, *:before, *:after {-webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box;}


html {overflow-y: scroll;}
body {color:#fff; height:100%; background: #fff;}
body, input, textarea {font-family: 'Tracklister', sans-serif;}
img {border:0; }
a {color:inherit; text-decoration:none;}
a:hover {text-decoration:none;}
:focus {outline:0;}

html, #wrapper {height:100%;}

body > #wrapper {height:auto; min-height:100vh; margin:0;}

img { display: block; max-width: 100%;}

.desktop {display: none;}
@media (min-width: 769px) {
	.desktop {display: block;}
}

h1,h2,h3,h4,h5,h6 {font-weight:300; margin: 0;}

ul, li {list-style:none;} fieldset {border:0;} textarea {resize:none;}

#wrapper { background: #fff;}

.wrap-loading {width: 100%; height: 100%; top: 0; left: 0; position: fixed; background: rgba(0,0,0,.6) url(../images/loading.svg?v=20260328) center no-repeat; z-index: 10000; display: none;}

/* ===== ERROR 404 ===== */
.home .container { display: flex; flex-direction: column; align-items: center; justify-content: start; flex: 1; padding: 40px; text-align: center; }
.home .container .logo { width: 150px; margin: 0 auto; }
.home .container .contato { color: #FFF; }
.home .container .contato h1 { color: #FFF; font-size: 24px; margin-bottom: 10px; }
.home .container .contato p { color: #FFF; }

/* ===== ANIMAÇÕES ===== */
@keyframes fadeInUp {
	from { opacity: 0; transform: translateY(20px); }
	to { opacity: 1; transform: translateY(0); }
}

@keyframes fadeIn {
	from { opacity: 0; }
	to { opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
	.home .hero-content > *,
	.home .info-section,
	.home .info-content > * { animation: none !important; opacity: 1 !important; }
}

/* ===== HOME - Novo Layout ===== */
.home { width: 100%; margin: 0; position: relative; display: flex; flex-direction: column; min-height: 100vh; background-size: cover; background-position: center; background-repeat: no-repeat; animation: fadeIn 0.8s ease-out; }
.home { background-image: url(../images/fundo-mobile.jpg?v=20260328); }

/* Hero Section */
.home .hero { position: relative; width: 100%; flex: 1; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.home .hero-content { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 24px; text-align: center; max-width: 500px; margin: 0 auto; }
.home .hero-content .logo { width: 200px; opacity: 0; animation: fadeInUp 0.6s ease-out 0.1s forwards; }
.home .hero-content .logo img { width: 100%; height: auto; transition: transform 0.4s ease; }
.home .hero-content .logo:hover img { transform: scale(1.03); }
.home .hero-content-text { opacity: 0; animation: fadeInUp 0.6s ease-out 0.25s forwards; }
.home .hero-content h1 { color: #fff; font-size: 55px; font-weight: 700; margin: 0; text-shadow: 0 2px 8px rgba(0,0,0,0.4); line-height: 1; }
.home .hero-content .slogan { color: #fff; font-size: 20px; text-shadow: 0 1px 4px rgba(0,0,0,0.3); }
.home .hero-content .btn-cta { display: flex; align-items: center; justify-content: center; background: linear-gradient(to bottom, #EE0000, #FF2626); color: #fff; font-size: 22px; font-weight: 700; border-radius: 12px; transition: transform 0.3s ease, box-shadow 0.3s ease; aspect-ratio: 595 / 170; opacity: 0; animation: fadeInUp 0.6s ease-out 0.5s forwards; }
.home .hero-content .btn-cta:hover { transform: scale(1.05); box-shadow: 0 4px 20px rgba(238,0,0,0.5); }

/* Info Section / Footer - sempre visível, 3 colunas, fundo semi-transparente para imagem aparecer */
.home .info-section { background: rgba(232, 232, 232, 0.9); padding: 30px 20px; flex-shrink: 0; border-radius: 20px 20px 0 0; opacity: 0; animation: fadeInUp 0.6s ease-out 0.6s forwards; }
.home .info-content { max-width: 1200px; margin: 0 auto; display: flex; align-items: center; justify-content: center; gap: 20px 40px; }
.home .hero-content-text { display: flex; flex-direction: column; align-items: center; gap: 5px; }
.home .info-item { display: flex; align-items: center; gap: 15px; color: #333; transition: transform 0.3s ease; }
.home .info-item:hover { transform: translateY(-2px); }
.home .info-horario { justify-self: end; }
.home .info-horario img { width: 50px; height: 50px; flex-shrink: 0; }
.home .info-horario p { font-size: 16px; line-height: 1.2; margin-bottom: 0; }
.home .info-horario p span { font-weight: 800;  }
.home .btn-evento { display: flex; align-items: center; font-weight: normal; justify-content: center; width: 215px; aspect-ratio: 255 / 87; box-sizing: border-box; text-align: center; background: #616161; color: #fff; font-size: 20px; padding: 14px 20px; border-radius: 8px; letter-spacing: 0.5px; transition: background 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease; box-shadow: 0 2px 8px rgba(0,0,0,0.15); line-height: 1;  }
.home .btn-evento:hover { background: #333; transform: scale(1.02); box-shadow: 0 4px 12px rgba(0,0,0,0.2); }
.home .info-redes { flex-direction: column; gap: 12px; justify-self: center; }
.home .info-redes span { font-size: 16px; font-weight: 200; color: #333; text-align: center; line-height: 1; }
.home .redes-sociais { display: flex; gap: 15px; justify-content: center; }
.home .redes-sociais a { width: 40px; height: 40px; }
.home .redes-sociais img { width: 100%; height: auto; transition: transform 0.3s ease; }
.home .redes-sociais a:hover img { transform: scale(1.1); }

/* Desktop */
@media (min-width: 769px) {
	.home { background-image: url(../images/fundo.jpg?v=20260328); }
	.home .hero-content { gap: 42px; }
	.home .hero-content .logo { width: 260px; }
	.home .hero-content h1 { font-size: 55px; }
	.home .hero-content .slogan { font-size: 27px; }
	.home .hero-content .btn-cta { width: 320px; font-size: 36px; }
	.home .info-horario { justify-self: end; }
	.home .info-horario p { font-size: 18px; }
	.home .info-redes { justify-self: start; }
	.home .container { justify-content: center; }
}

/* Tablet - 3 colunas centralizadas */
@media (max-width: 768px) {
	.home .info-content { flex-direction: column; gap: 15px 25px; }
	.home .info-horario { justify-self: center; }
	.home .info-redes { justify-self: center; flex-direction: row; }
	.home .hero-content .btn-cta { width: 240px; font-size: 28px; }
	.home .hero-content { gap: 30px; }
	.home .hero-content .logo { width: 160px; }
	.home .hero-content h1 { font-size: 40px; }
	.home .hero-content .slogan { font-size: 20px; }
	.home .info-section { padding: 25px 15px; }
	.home .info-horario p { font-size: 13px; }
	.home .btn-evento { font-size: 12px; padding: 12px 15px; width: 215px; aspect-ratio: initial; }
	.home .info-redes span { font-size: 13px; }
	.home .info-horario img { width: 37px; height: 37px; }
	.home .redes-sociais a { width: 30px; height: 30px; }
	.home .redes-sociais { gap: 8px; }
}