/*
    Theme Name: Atom Theme
    Theme URI: https://atomdigital.com.br/
    Author: Higor Paulo | Atom Digital
    Author URI: https://atomdigital.com.br/
    Description: Website/One Page/Landing Page
    Version: 2025.1
    License: Atom Digital
    License URI: https://atomdigital.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: #171718;
    --color-neutral-200: #818181;
    --color-neutral-300: #686868;
    --color-neutral-400: #747474;
    --color-neutral-500: #D0D1CF;
    --color-neutral-600: #E0E0E0;
    --color-neutral-700: #f3f3f3;
    --color-neutral-800: #f7f7f7;
    --color-neutral-900: #FFFFFF;
    --color-primary: #4caf50;
    --color-secondary: #185d1b;
    --color-tertiary: #3b82f680;
    --color-green: #0bcb52;
    /* Fonts Family */
    --font-family-01: "Rubik", sans-serif;
}
html{
    font-size: 16px;
    font-weight: 400;
    scroll-behavior: smooth;
}
body{
    font-family: var(--font-family-01);
    color: var(--color-neutral-100);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-weight: 400;
}
.container{
    max-width: 1370px;
}
@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;
    color: var(--color-neutral-100);
    margin-bottom: .5rem;
}
input,
textarea,
select{
    width: 100%;
    background: var(--color-neutral-900);
	font-size: 1rem;
    touch-action: manipulation;
    color: var(--color-neutral-200);
    border: 1px solid rgb(206, 212, 218);
    padding: .8rem 1rem;
    border-radius: 5px;
}
textarea{
    min-height: 7rem;
    max-height: 7rem;
}
select{
    appearance: none !important;
    -webkit-appearance: none !important;
    background: transparent url(./assets/img/default-dropdown.svg) no-repeat right 1rem center;
    background-size: .6rem; /* Tamanho da imagem */
}

select option {
    background-color: var(--color-primary);
    color: var(--color-neutral-900);
    border: 1px solid var(--color-primary);
}
/*********** 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-tertiary{ background-color: var(--color-tertiary); }
.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); }
.text-color-tertiary{ color: var(--color-tertiary); }
.text-color-green{ color: var(--color-green); }
/*********** 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: 2rem; /* 32px */ }
.heading-size-md { font-size: 2.375rem; /* 38px */ }
.heading-size-lg { font-size: 2.5rem; /* 40px */ }
.heading-size-xl { font-size: 3.125rem; /* 50px */ }
.heading-size-xxl { font-size: 3.5rem; /* 56px */ }

@media screen and (max-width: 576px) {
    .heading-size-xxl { font-size: calc(3.813rem - 50%); }
    .heading-size-xl { font-size: calc(3.125rem - 50%); }
    .heading-size-lg { font-size: calc(3rem - 50%); }
    .heading-size-md { font-size: calc(2.625rem - 50%); }
}
.text-size-xs { font-size: 0.656rem;  /* 10.5px */ }
.text-size-sm { font-size: 0.75rem; /* 12px */ }
.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 */ }

/*********** 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: var(--color-primary);
    color: var(--color-neutral-900);
    width: 100%;    
    max-width: 400px;
    padding: 1rem 1.7rem;
	font-size: 1.25rem; /* 20px */
    line-height: 1;  
    font-weight: 500;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    border: 0;
    border-radius: 8px;
    gap: .5rem;
    transition: all 0.5s ease;
}  
@media screen and (max-width: 576px) {
    .btn-style-01 {
        width: 100% !important;
    }
}
/*********** End Button ***********/

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

.swiper-pagination-bullet-active {
    background-color: var(--color-neutral-900);
    opacity: 1; 
}
.swiper-button-next, .swiper-button-prev {
    background: #d9d9d946;
    color: var(--color-neutral-900);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 39px;
    height: 39px;
    border-radius: 50%;
    border: .7px solid var(--color-neutral-900);
    padding: .7rem;
    top: 50%; 
    transform: translateY(-50%);
    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;
        padding: .5rem;
    }
}
/********* 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-neutral-900);
}

.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: 600px;
    object-fit: cover;
}

@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;
}
.gallery-lightbox-trigger img,
.gallery-lightbox-trigger video {
    transition: transform 0.5s ease;
}
.gallery-lightbox-trigger:hover img,
.gallery-lightbox-trigger:hover video {
    transform: scale(1.1);
}
/********* End Gallery Lightbox Styles *********/

/********* Start Typing Effect Styles *********/
.typing-container {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    width: 100%;
}
@media screen and (max-width: 576px) {
    .typing-container {
        min-height: 120px;
    }
}

.typing-text {
    width: 100%;
    min-height: 1.2em;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: inline-block;
    opacity: 0;
    visibility: hidden;
}

.typing-text.active {
    opacity: 1;
    visibility: visible;
}

.typing-text::after {
    content: '|';
    display: inline-block;
    color: var(--color-secondary);
    animation: blink 1s infinite;
    margin-left: 2px;
}

.typing-text.typing-complete::after {
    display: none;
}

@keyframes blink {
    0%, 50% {
        opacity: 1;
    }
    51%, 100% {
        opacity: 0;
    }
}
/********* End Typing Effect Styles *********/