/*
    Theme Name: Atom Theme
    Theme URI: https://hxdigital.com.br/
    Author: Higor Paulo | Hx Digital
    Author URI: https://hxdigital.com.br/
    Description: Website/One Page/Landing Page
    Version: 2025.1
    License: Atom Digital
    License URI: https://hxdigital.com.br/
    Tags: criação de páginas web Brasil, criação de páginas web Goiânia, desenvolvimento de sites Goiânia, desenvolvimento de sites responsivos Goiânia, web design Goiânia, otimização SEO, análise de desempenho de sites, técnicas de otimização para sites, gestão de redes sociais, estratégias de marketing nas redes sociais, produção de conteúdo para websites
    Text Domain: Atom Digital
*/

/* Cores customizadas */
:root {
    --color-neutral-100: #131313;
    --color-neutral-200: #484848;
    --color-neutral-300: #54565B;
    --color-neutral-400: #747474;
    --color-neutral-500: #e9e9e9;
    --color-neutral-600: #F8FAF9;
    --color-neutral-700: #EFEFEF;
    --color-neutral-800: #f9f9f9;
    --color-neutral-900: #FFFFFF;
    --color-primary: #1B923E;
    --color-secondary: #014430;
    --color-green: #0AA02D;

    /* Fonts Family */
    --font-family-01: "DM Sans", sans-serif;
    --font-family-02: "Open Sans", sans-serif;
}
html{
    font-size: 16px;
    font-weight: 400;
    scroll-behavior: smooth;
}
body{
    background-color: var(--color-neutral-800) !important;
    font-family: var(--font-family-02);
    color: var(--color-neutral-300);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-weight: 400;
}
h1, h2, h3, h4, h5, h6{
    font-family: var(--font-family-01);
}
@media screen and (max-width: 999px) {
    html{
        font-size: 15px;
    }
}

@media screen and (max-width: 768px) {
    html{
        font-size: 14px;
    }
}

@media screen and (max-width: 576px) {
    html{
        font-size: 13px;
    }
}
form{
    touch-action: manipulation;
}
form label{
	font-size: 1rem;
}
form .check-input{
    width: 1rem;
    height: 1rem;
    border-radius: 50%;
}
input,
textarea,
select {
    width: 100%;
    border-radius: 50px;
    border: 1px solid transparent;
    background: 
        linear-gradient(#fff, #fff) padding-box,
        linear-gradient(91.6deg, rgba(249, 249, 249, 0.8) 0%, #D9D9D9 26.11%, rgba(249, 249, 249, 0.9) 100.02%) border-box;
    font-size: 1rem;
    touch-action: manipulation;
    color: var(--color-neutral-300);
    padding: 1rem;
}

select {
    appearance: none !important;
    -webkit-appearance: none !important;
    background:
        linear-gradient(#fff, #fff) padding-box,
        linear-gradient(91.6deg, rgba(249, 249, 249, 0.8) 0%, #D9D9D9 26.11%, rgba(249, 249, 249, 0.9) 100.02%) border-box;
    background-size: 100% 100%, 100% 100%;
    background-repeat: no-repeat;
    position: relative;
    z-index: 1;
}
.select-wrapper {
    position: relative;
    display: inline-block;
    width: 100%;
}

.select-wrapper select {
    width: 100%;
    padding-right: 2.5rem; /* espaço para o ícone */
}

.select-wrapper::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 1rem;
    transform: translateY(-50%);
    width: .6rem;
    height: .6rem;
    background: url('./assets/img/default-dropdown.svg') no-repeat center center;
    background-size: contain;
    pointer-events: none;
    z-index: 2;
}

select option {
    background-color: var(--color-neutral-900);
    color: var(--color-neutral-300);
    border: 1px solid var(--color-neutral-900);
}
/*********** Start Fonts ***********/
.font-family-01{
    font-family: var(--font-family-01);
}
.font-family-02{
    font-family: var(--font-family-02);
}
/*********** End Fonts ***********/

/*********** Start Background ***********/
.bg-color-neutral-100{
	background-color: var(--color-neutral-100);
}
.bg-color-neutral-200{
	background-color: var(--color-neutral-200);
}
.bg-color-neutral-300{
	background-color: var(--color-neutral-300);
}
.bg-color-neutral-400{
	background-color: var(--color-neutral-400);
}
.bg-color-neutral-500{
	background-color: var(--color-neutral-500);
}
.bg-color-neutral-600{
	background-color: var(--color-neutral-600);
}
.bg-color-neutral-700{
	background-color: var(--color-neutral-700);
}
.bg-color-neutral-800{
	background-color: var(--color-neutral-800);
} 
.bg-color-neutral-900{
	background-color: var(--color-neutral-900) !important;
}
.bg-color-primary{
	background-color: var(--color-primary);
}
.bg-color-secondary{
    background-color: var(--color-secondary);
}
.bg-color-green{
    background-color: var(--color-green);
}
/*********** End Background ***********/

/*********** Start Colors ***********/
.text-color-neutral-100{
	color: var(--color-neutral-100) !important;
}
.text-color-neutral-200{
	color: var(--color-neutral-200);
}
.text-color-neutral-300{
	color: var(--color-neutral-300);
}
.text-color-neutral-400{
	color: var(--color-neutral-400);
}
.text-color-neutral-500{
	color: var(--color-neutral-500);
}
.text-color-neutral-600{
	color: var(--color-neutral-600);
}
.text-color-neutral-700{
	color: var(--color-neutral-700);
}
.text-color-neutral-800{
	color: var(--color-neutral-800);    
} 
.text-color-neutral-900{
	color: var(--color-neutral-900);
}
.text-color-primary{
	color: var(--color-primary) !important;
}
.text-color-secondary{
	color: var(--color-secondary);    
}
/*********** End Colors ***********/

/*********** Start Text sizes ***********/
.heading-size-xxs {
	font-size: 1.375rem; /* 22px */
}
.heading-size-xs {
	font-size: 1.5rem; /* 24px */
}
.heading-size-sm {
	font-size: 2.25rem; /* 36px */
}
.heading-size-md {
	font-size: 2.625rem; /* 42px */
}
.heading-size-lg {
	font-size: 2.875rem; /* 46px */
}
.heading-size-xl {
	font-size: 3.25rem; /* 52px */
}
.heading-size-xxl {
	font-size: 3.813rem; /* 61px */
}

@media screen and (max-width: 576px) {
    .heading-size-xxl {
        font-size: calc(3.313rem - 50%);
    }
    .heading-size-xl {
        font-size: calc(3.25rem - 50%);
    }
    .heading-size-lg {
        font-size: calc(2.875rem - 70%);
    }
    .heading-size-md {
        font-size: calc(2.625rem - 20%);
    }
}
.text-size-xs {
	font-size: 0.656rem;  /* 10.5px */
}
.text-size-sm {
	font-size: 0.8125rem; /* 13px */
}
.text-size-md {
	font-size: 0.875rem; /* 14px */
}
.text-size-lg {
	font-size: 1rem !important; /* 16px */
}
.text-size-xl {
	font-size: 1.125rem; /* 18px */    
}
.text-size-xxl {
	font-size: 1.25rem; /* 20px */
}

@media screen and (max-width: 576px) {

}
/*********** End Text sizes ***********/

/*********** Start Font Weight ***********/
.font-weight-300{
    font-weight: 300;
}
.font-weight-400{
    font-weight: 400;
}
.font-weight-500{
    font-weight: 500;
}
.font-weight-600{
    font-weight: 600;
}
.font-weight-700{
    font-weight: 700;
}
.font-weight-800{
    font-weight: 800;
}
/*********** End Font Weight ***********/

/*********** Start Button ***********/
.btn-style-01{
    background-color: #CDDAD6;
    color: var(--color-secondary);
    border: 1.2px solid #FFFFFF;
    border-radius: 100px;
    padding: 1.2rem 3rem;
	font-size: 1.188rem; /* 19px */  
    font-family: var(--font-family-01);
    font-weight: 600;
    letter-spacing: 0.05em;
    line-height: 1;  
    display: inline-flex;
    justify-content: center;
    align-items: center;    
    gap: .6rem;
    transition: all .3s ease;
}
.btn-style-01:hover{
    background-color: var(--color-neutral-900);
    border: 1.2px solid #CDDAD6;
}   
.btn-style-02{
    background-color: var(--color-primary);
    color: var(--color-neutral-900);
    border: 1.2px solid var(--color-primary);
    border-radius: 100px;
    padding: 1.2rem 2rem;
	font-size: 1.188rem; /* 19px */  
    font-family: var(--font-family-01);
    font-weight: 600;
    letter-spacing: 0.05em;
    line-height: 1;  
    display: inline-flex;
    justify-content: center;
    align-items: center;    
    gap: .6rem;
    transition: all .3s ease;
}   
.btn-style-03 {
    background: transparent;
    color: var(--color-secondary);
    border: 1px solid var(--color-primary);
    border-radius: 100px;
    padding: .6rem .8rem;
	font-size: 1rem;  
    font-family: var(--font-family-01);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .6rem;
    transition: all .3s ease;
}
.btn-style-04{
    background-color: var(--color-secondary);
    color: var(--color-neutral-900);
    border: 1px solid var(--color-primary);
    border-radius: 50px;
    padding: 1rem 1.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .6rem;
    transition: all .3s ease;
    font-family: var(--font-family-01);
    font-weight: 600;
    letter-spacing: 0.05em;
    line-height: 1;
    font-size: 1.188rem; /* 19px */
}
/*********** End Button ***********/

/********* Start Swiper Config *********/
.swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    opacity: 0.5;
    background-color: var(--color-neutral-400);
}

.swiper-pagination-bullet-active {
    background-color: var(--color-secondary);
    opacity: 1; 
}
.swiper-button-next, .swiper-button-prev {
    background: var(--color-secondary);
    color: var(--color-neutral-900);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 41px;
    height: 41px;
    border-radius: 50%;
    border: .7px solid var(--color-primary);
    padding: .7rem;
    margin-top: auto;
}
.swiper-button-next:after, 
.swiper-button-prev:after {
    content: '';
    width: 25px;
    height: 25px;
    background-size: 100%;
    background-repeat: no-repeat;
    background-position: center;
}
.swiper-button-next:after {
    background-image: url(./assets/img/arrow-right.svg) !important;
}
.swiper-button-prev:after {
    background-image: url(./assets/img/arrow-left.svg) !important;
}
@media screen and (max-width: 768px) {
    .swiper-button-next, .swiper-button-prev {
        width: 30px;
        height: 30px;
    }
}
@media screen and (max-width: 576px) {
    .swiper-button-next, .swiper-button-prev {
        width: 26px;
        height: 26px;
    }
}
/********* End Swiper Config *********/

@media screen and (max-width: 576px) {
    .container{
        padding: 0 30px;
    }
}

/********* Gallery Lightbox Styles *********/
#gallery-lightbox-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.9);
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
}

#gallery-lightbox-modal.show {
    display: flex !important;
}

.gallery-lightbox-content {
    position: relative;
    width: 90%;
    max-width: 1200px;
    height: 90%;
    max-height: 800px;
    display: flex;
    align-items: center;
    justify-content: center;
}

#gallery-lightbox-close {
    position: absolute;
    top: -40px;
    right: 0;
    background: none;
    border: none;
    color: white;
    font-size: 2rem;
    cursor: pointer;
    z-index: 10001;
    padding: 10px;
    line-height: 1;
}

#gallery-lightbox-close:hover {
    color: var(--color-primary);
}

.gallery-lightbox-swiper {
    width: 100%;
    height: 100%;
}

.gallery-lightbox-swiper .swiper-slide {
    display: flex;
    align-items: center;
    justify-content: center;
}

.gallery-lightbox-swiper .swiper-slide img,
.gallery-lightbox-swiper .swiper-slide video {
    width: auto;
    height: 100%;
    max-height: 500px;
    object-fit: cover;
    border-radius: 8px;
}

.gallery-lightbox-prev,
.gallery-lightbox-next {
    color: white !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(255, 255, 255, 0.3) !important;
}

.gallery-lightbox-prev:hover,
.gallery-lightbox-next:hover {
    background: var(--color-primary) !important;
}

@media screen and (max-width: 768px) {
    .gallery-lightbox-content {
        width: 95%;
        height: 85%;
    }
    
    #gallery-lightbox-close {
        top: -35px;
        font-size: 1.5rem;
    }
}

.gallery-lightbox-trigger {
    cursor: pointer;
    transition: transform 0.3s ease;
}
/********* End Gallery Lightbox Styles *********/
.content-text ul {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.content-text ul li{
    list-style: disc;
    margin-left: 1rem;
}