* {
    font-family: 'Poppins';
    scroll-padding-top: 100px;
}

@font-face {
  font-family: 'Poppins'; 
  src: url(/assets/website/font/Poppins-Regular.ttf); 
}

@font-face {
  font-family: 'Poppins Bold'; 
  src: url(/assets/website/font/Poppins-Bold.ttf); 
}

@font-face {
  font-family: 'Poppins SemiBold'; 
  src: url(/assets/website/font/Poppins-SemiBold.ttf); 
}

@font-face {
  font-family: 'Poppins Light'; 
  src: url(/assets/website/font/Poppins-Light.ttf); 
}

@font-face {
  font-family: 'ArchivoBlack'; 
  src: url(/assets/website/font/ArchivoBlack-Regular.ttf); 
}

/* ////////////////// COLORS \\\\\\\\\\\\\\\\\ */

:root {
    --dark: #171717;
    --orange: #F0730D;
    --text: #222222;
}

/* ////////////////// LINE \\\\\\\\\\\\\\\\\ */

hr {
    margin: 20px 0!important;
    border: 0;
    background-image: linear-gradient(to right, #E43818, #E6850D);
    opacity: 1!important;
    height: 1px;
    width: 60%;
}

/* ////////////////// TEXT \\\\\\\\\\\\\\\\\ */

h1 {
    font-size: 55px!important;
    font-family: 'Poppins Bold'; 
}

h2 {
    font-size: 45px!important;
    font-family: 'ArchivoBlack'; 
    color: var(--dark)!important;
}

h3 {
    font-size: 22px!important;
    font-family: 'Poppins Regular';
    color: var(--dark)!important;
}

h4 {
    font-size: 25px!important;
    font-family: 'Poppins SemiBold';
    color: white!important;
}

h5 {
    font-size: 20px!important;
    font-weight: 300!important;
    color: var(--darkbeige)!important;
}

h6 {
    color: var(--dark)!important;
    font-weight: 300!important;
    font-size:16px!important;
}

p {
    font-size: 14px;
    font-weight: 300!important;
}

p span {
    color: var(--orange);
    font-family: 'Poppins Light';
}

@media (max-width:768px) {
    h1 {
        font-size: 30px !important;
    }

    h2 {
    font-size: 20px !important;
    }
    h3 {
    font-size: 20px !important;
    }

    h4 {
        font-size: 16px !important; 
    }
}

@media (max-width:991px) {
    h1 {
        font-size: 32px !important;
    }

    h2 {
    font-size: 22px !important;
    }
    h3 {
    font-size: 20px !important;
    }

    h4 {
        font-size: 18px !important; 
    }
}


/* ////////////////// ANIMATIONS \\\\\\\\\\\\\\\\\ */

/* reveal items on scroll */

.reveal-item {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.8s ease, transform 0.8s ease;
}

.reveal-item.show {
    opacity: 1;
    transform: translateY(0);
}

/* ////////////////// HEROS \\\\\\\\\\\\\\\\\ */

.overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, #00000091, #00000014);
}


.textlight { color: var(--orange)!important;}
.textdark { 
    color: var(--dark)!important;
    font-weight: 400!important;
}

@media (max-width:768px) {
    .banner {
        height: 270px;
    }

    .home-title {
        font-size: 45px !important;
    }

    .banner h4 {
        width: 80%;
    }
}

/* ////////////////// BUTTONS \\\\\\\\\\\\\\\\\ */

button, .btn.primary {
    border-radius: 5rem!important;
    padding: 8px 20px;
    outline: none;
    font-weight: 500;
    border: none;
    margin: 10px 0!important;
    font-size: 15px!important;
    text-transform: uppercase!important;
    color: white;
    border-top-left-radius: 0px !important;
    background: linear-gradient(to right, #E43818, #E6850D, #E43818);
    background-size: 200% auto;
    transition: background-position 0.5s ease;}

button:hover , .btn.primary:hover{
    background-position: right center;
}

.btn-white {
    background: white;
    color: var(--orange);
}

.btn-outline {
    border: 2px solid var(--orange);
    background: white;
    color: var(--orange);
}


/* ////////////////// BACKGROUNDS \\\\\\\\\\\\\\\\\ */

.bgdark { background-color: var(--dark);}
.bglight { background-color: var(--beige);}
.bgbrown {background-color: var(--brown);}
.bgradient {
    background: linear-gradient(to right, #E43818, #E6850D, #E43818);
    background-size: 200% auto;
    transition: background-position 0.5s ease;
}

/* ////////////////// HOME \\\\\\\\\\\\\\\\\ */

.about-img {
    overflow: hidden;
    width: 100%;
    border-radius: 2rem;
    border-top-left-radius: 0;
    display: flex;
    justify-content: center;
    height: 300px;
}

.about-img img {
        object-fit: contain;
}

.about-text-card {
    padding: 80px 20px;
    display: flex;
    align-items: center;
    border-radius: 2rem;
    border-top-left-radius: 0;
    height: 300px;
}

@media (max-width:768px) {
    .about-text-card {
        height: auto;
        padding: 40px 20px;
    }
}

@media (max-width:991px){
    /* .navbar-collapse.collapse {
        display: flex !important;
        height: auto !important;
        padding-bottom: 0;
        overflow: visible !important;
    } */

    .collapse:not(.show) {
        display: none!important;
    }
}

.navbar-toggler {
    border: none;
    color: white;
}
.navbar-toggler-icon{
    background-image: url('/assets/website/img/icons/menu.svg')!important;
}

/* ///////////////////// SPACES \\\\\\\\\\\\\\\\\\\\\\\ */

/* gallery */
.slider-container {
  padding: 50px 0;
}

.slider {
  width: 100%;
  margin: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  overflow-x: hidden;
}

.track {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.5s ease;
}

.slide {
  flex: 0 0 calc(100% / 3 - 30px); 
  margin: 0 15px;
  transition: all 0.5s ease;
  opacity: 0.4;
  transform: scale(0.85);
  border-radius: 20px;
  overflow: hidden;
  padding: 25px;
}

@media  (max-width: 991px) {    
    .slide {
        flex: 0 0 calc(100%/2); 
        padding: 0;
    }
}

.slide img {
  width: 100%;
  height: 500px;
  object-fit: cover;
  border-radius: 20px;
}

/* foco */
.slide.active {
  opacity: 1;
  transform: scale(1.1);
}

/* vizinhos */
.slide.prev,
.slide.next {
  opacity: 0.7;
  transform: scale(0.95);
}

/* dots */
.dots {
  margin-top: 20px;
}

.dots span {
  display: inline-block;
  width: 10px;
  height: 10px;
  margin: 5px;
  background: #e5e5e5;
  border-radius: 50%;
  cursor: pointer;
  transition: all 0.3s ease;
}

.dots span.active {
  width: 25px;
  border-radius: 10px;
  background: var(--dark);
}

/* ////////////// */

.spaces-img { 
    border-radius: 2rem;
    border: 1px solid var(--beige);
    padding: 8px;
    width: 90%;
}

.img-item  {
    border-radius: 2rem;
    overflow: hidden;
    height: 260px;
    display: inline;
    align-items: center;
}

.spaces-img img{
    width: 100%;
    object-fit: cover;
    border-radius: 2rem;
}

.spaces-text {
    margin: 15px 0;
}

/* ////////////////// ABOUT US \\\\\\\\\\\\\\\\\ */

.banner-about {
     background: url('/assets/website/img/sobrenos-banner.png'); 

    background-size: cover; 
}

/* ////////////////// SERVICES \\\\\\\\\\\\\\\\\ */

.grid {
			flex-wrap: wrap;
            display: grid;
            grid-template-columns: 1fr 1fr 1fr;
            grid-template-rows: 200px 200px 200px;
            gap: 20px;
		}
		.grid > div {
			width: 100% ;
		}
		@media only screen and (min-device-width: 740px) {
			.grid {
				/*max-width: 75%;*/
			    display: grid;
			    grid-template-columns: repeat(auto-fit, minmax(9%, 1fr));
			    grid-template-rows: repeat(auto-fill, minmax(4%, 1fr)  );
			    grid-column-gap: 1rem;
			    grid-row-gap: 1rem;
			    margin-bottom: 1rem;
			}
			.grid > div {
				display: flex;
				flex-direction: column;
				align-items: stretch;
				justify-content: stretch;
				height: 100%;			
				/*width: 25%;*/
				overflow: hidden;
			}

			.grid > div:hover img {
				/*transform: translateX(-2px) scale(1.1);*/
			}

		}
		.grid img {
			transform-origin: center;
			transition: 2s ease all;
			margin-bottom: 0;
 			width: 100%;
 			height: 100%;
 			display: block;
 			object-fit: cover;
		}

.grid-card {
    padding: 40px;
    border-radius: 5px;
}
.grid-card-img   {
    border-radius: 2rem;
    overflow: hidden;
}
.grid-card-img img {
    object-fit: cover;
}
.services-img-card {
    padding: 50px 100px 50px 50px!important;
}

.services-text-card {
    padding: 50px 200px 50px 50px!important;
}

.services-topics-card {
    min-height: 300px;
    max-height: 400px;
    padding: 50px 50px 50px 50px!important;
}

@media (max-width: 768px) {
    .grid {
        display: flex;
    }
}

@media (max-width: 991px) {

    .services-topics-card {
        max-height: unset;
    }
    .services-text-card , .services-img-card {
        padding: 50px!important;
    }

}

/* ////////////////// CONTACTS \\\\\\\\\\\\\\\\\ */

.form-control {
    background: #F1F1F1!important;
    border-radius: 5rem!important;
    border-top-left-radius: 0px !important;
    border: 1px solid white!important;
    color: var(--dark)!important;
    font-size: 14px!important;
    height: 45px;
    padding-left: 20px!important;
}

.form-control:focus {
    box-shadow: 0 0 0 transparent;
    background-color: #fff0e4 !important;
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
    
}

.form-control ::placeholder {
    color: var(--orange)!important;
}

.form-label {
    font-size: 14px;
    font-weight: 400;
    color: white;
}

.form-group.is-required > label:after, .label-required:after {
    color: var(--dark)!important;
    text-shadow: 0 0 2px  var(--dark)!important;
}

.checkbox input[type=checkbox] {
    margin-left: -14px;
}

/* ////////////////// HEADER \\\\\\\\\\\\\\\\\ */
nav .container-fluid {
    border-top-right-radius: 3rem;
    border-bottom-right-radius: 3rem;
    padding: 10px 40px;
    box-shadow: 3px 3px 10px #dddd;
}
.navbar-brand img{
    height: 100%;
    width: 100%;
}
.navbar-brand {
    height: 75px;
}
.nav-link {
    font-size: 16px!important;
    color: var(--dark)!important;
    text-transform: uppercase;
    font-weight: 500!important;
}

.nav-link:hover {
    color: var(--orange)!important;
    text-decoration: none;

}
.navbar-toggler {
    background: white;
    border: none!important;
}

button:focus:not(:focus-visible) {
    box-shadow: none;
}

@media (max-width:991px) {
    .navbar-brand {
        height: 65px;
    }

    .navbar-nav {
        display: flex;
        width: 100%;
        margin-left: 0;
    }
    
}

/* ////////////////// FOOTER \\\\\\\\\\\\\\\\\ */

footer ul, header ul {
    list-style: none;
    display: flex;
}

.footer-link {
    color: white!important;
    font-size: 16px!important;
    font-weight: 300!important;
    padding: 10px 20px;
    text-decoration: none;
}

.footer-link:hover {
    color: var(--beige);
}

.footer-btn {
    position: absolute;
    right: 0;
}

@media (max-width:768px) {
    .footer-menu {
        display: block!important;
        text-align: center;
    }

    .footer-btn {
        display: flex;
        justify-content: center;
        width: 100%;
        margin: 20px 0;
    }
}
/* ////////////////// LEGAL \\\\\\\\\\\\\\\\\ */

.list-group-item.active {
    background-color: var(--darkbeige)!important;
    border-color: var(--darkbeige)!important;
}

.list-group-item {

}