:root {
    --primary: #0A4076;
    --dark-blue: #213f59;
    --text-muted-light: #FAFAFACC;
    --light-blue: #42bed7;
}

body {
    font-family: Inter, system-ui, sans-serif;
}

textarea {
    resize: none;
}

.swiper {
    width: 100%;
    height: 100vh;
}

.gradient-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 90%;
    height: 100%;
    background: linear-gradient(
            to right,
            rgba(255, 255, 255, 0.85) 0%,
            rgba(255, 255, 255, 0.7) 25%,
            rgba(255, 255, 255, 0.6) 50%,
            rgba(255, 255, 255, 0.5) 70%,
            rgba(255, 255, 255, 0.2) 85%,
            rgba(255, 255, 255, 0.1) 90%,
            rgba(255, 255, 255, 0.0) 100%
    );
    z-index: 1;
}

.swiper-slide {
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    position: relative;
}

.slide-content {
    position: relative;
    z-index: 2;
}

.bg-transparent {
    background: rgba(255, 255, 255, 0.9) !important;
    color: #333;
}

.text-muted-light {
    color: var(--text-muted-light);
}

.text-muted-light-link {
    color: var(--text-muted-light);
}

.text-muted-light-link:hover {
    color: white;
}

.border-grey {
    border-color: #dcdfe4;
}

.border-gainsboro {
    border-color: #dcdfe480;
}

.link-active {
    color: #062647 !important;
}

.text-greyish-blue {
    color: #60809f !important;
}

.card-img-top {
    height: 12rem;
    object-fit: cover;
}

.collapse.show {
    background-color: #fff;
}

.navbar-custom {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    background-color: transparent !important;
    z-index: 1000;
    transition: background-color 0.3s ease;
    padding: 0.7rem 5.5rem !important;
}

.navbar-toggler {
    border: none;
    padding: 0.35rem 0.5rem;
}

.navbar-toggler:focus {
    box-shadow: none;
    background-color: var(--light-blue);
}

.navbar-toggler-icon {
    background-size: 1.5rem 1.5rem;
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(0,0,0,1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}

.text-white {
    color: #FAFAFA !important;
}


.link-alterar-idioma {
    color: #60809f;
    transition: color 0.3s ease;
}

.link-alterar-idioma:hover {
    color: black;
    background-color: var(--light-blue);
}

.link-active:hover {
    background-color: var(--light-blue);
}

.bg-primary {
    background-color: var(--primary) !important;
}

.text-primary {
    color: #062647 !important;
}

.text-subtle-primary {  
    color: var(--primary) !important;
}

.navbar {
    transition: background-color 0.3s ease;
    background-color: transparent !important;
}

.navbar.scrolled {
    position: sticky !important;
    background-color: #f9fafbcc !IMPORTANT;
    backdrop-filter: blur(30px);
    border-bottom: #dcdfe4 2px solid;
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}

.titulo-home {
    font-size: 4.5rem !important;
}

.descricao-home {
    font-size: 1.25rem !important;
}

.px-10 {
    padding-right: 5.5rem !important;
    padding-left: 5.5rem !important;
}

.w-45 {
    width: 45% !important;
}

.w-60 {
    width: 60% !important;
}

.btn-custom {
    padding: 0.5rem 2rem;
}

.btn-action {
    background: linear-gradient(
            to bottom,
            #0c467f 0%,
            #165aa7 100%
    );
    color: #fff;
    font-weight: 600;
    font-size: 0.9rem !important;
    border: none;
    padding: 12px 24px;
    display: inline-block;
    text-align: center;
    transition: background 0.3s ease;
}

.btn-action:hover {
    background: linear-gradient(
            to bottom,
            #3a8de0 0%,
            #1b63b5 100%
    );
}

.btn-demo {
    border-color: #0a407680 !important;
}

.swiper-controls {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    align-items: baseline;
    z-index: 1051;
}

.swiper-button-prev,
.swiper-button-next {
    position: static;
    width: 70px;
    height: 35px;
    border-radius: 25%;
    background: #e1eef4;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
}

.swiper-button-prev:hover,
.swiper-button-next:hover {
    background: #fff;
}

.swiper-button-prev::after,
.swiper-button-next::after {
    font-size: 14px;
    color: #333;
}

.swiper-pagination {
    position: static;
}

.swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    background-color: #ccc;
    opacity: 1;
}

.swiper-pagination-bullet-active {
    background-color: #0d6efd;
}

.fw-bold-500 {
    font-weight: 500;
}

.fw-bold-600 {
    font-weight: 600;
}

.fw-bold-700 {
    font-weight: 700;
}

.swiper-button-prev::after, .swiper-button-next::after {
    font-size: 10px !important;
    color: #333;
    font-weight: bold;
}

.w-md-75 {
    width: 75% !important;
}

.f-14 {
    font-size: 0.875rem !important;
}

.f-18 {
    font-size: 1.125rem !important;
}

.f-20 {
    font-size: 1.25rem !important;
}

.f-36 {
    font-size: 2.25rem !important;
}

.f-48 {
    font-size: 3rem !important;
}

.text-acent {
    color: #42bed7 !important;
}

.mt-9 {
    margin-top: 5rem !important;
}

.mb-6 {
    margin-bottom: 3.5rem !important;
}

.section-codigo-de-autenticidade {
    background-color: #edf1f5;
    padding: 4rem 19rem !important;
}

.icones-codigo-de-autenticidade {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    transition: 0.3s;
}

.section-equipamentos-utilizados {
    background-color: #f5f7f8;
    padding: 5rem 19rem !important;
}

.section-nossa-tecnologia {
    background-color: #f5f7f8;
    padding: 6rem 5.6rem !important;
}

.icones-nossa-tecnologia {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background-color: #eff2f5;
    transition: 0.3s;
}

.gradient-dark-blue {
    background: linear-gradient(135deg, #0c457e, #1a66b2);
    color: #fff;
}

.gradient-blue {
    background: linear-gradient(135deg, #0288d1, #26c6da);
    color: #fff;
}

.indicator-card {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.indicator-card:hover {
    transition-duration: .3s;
    transform: translateY(-6px) scale(1.03);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2) !important;
}

.section-projetos-e-eventos {
    padding: 6rem 5.6rem !important;
    background-color: #f9fafb;
}

.filter-btn {
    border-radius: 9999px;
    padding: 0.5rem 1.5rem;
    border: 1px solid #dcdcdc;
    background: #fff;
    color: #062647;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;

    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
}

.filter-btn:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.12);
}

.filter-btn.active {
    background: linear-gradient(135deg, #0b447c, #1976d2);
    color: #fff;
    border: none;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.event-card {
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.event-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.15) !important;
}

.badge-evento {
    position: absolute;
    top: 12px;
    right: 12px;
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 999px;
    background-color: var(--primary);
    color: #FAFAFA;
    font-size: .75rem;
}

.section-contato {
    background: radial-gradient(circle at 20% 80%, #0a407633 0%, transparent 50%), radial-gradient(circle at 80% 20%, #1d8fc94d 0%, transparent 50%);
    padding: 6rem 11.5rem !important;
}

.btn-enviar-mensagem {
    background: linear-gradient(
            to bottom,
            #0c467f 0%,
            #165aa7 100%
    );
    color: #fff;
    font-weight: 600;
    font-size: 0.9rem !important;
    border: none;
    padding: 12px 24px;
    display: inline-block;
    text-align: center;
    border-radius: .75rem;
}

.btn-enviar-mensagem:hover, .btn-enviar-mensagem:active, .btn-enviar-mensagem:focus-visible {
    box-shadow: 5px -5px 15px #ccdcec;
    color: #fff !important;

}

.icones-contato {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 50%;
}

.gradient-icone-email {
    background: linear-gradient(135deg, hsl(210 85% 25%), hsl(210 75% 40%));
}
.gradient-icone-telefone {
    background: linear-gradient(135deg, hsl(200, 75%, 45%), hsl(190, 65%, 55%))
}
.gradient-horario-de-atendimento{
    background: linear-gradient(135deg, var(--primary) 0%, #1d8fc9 50%, #42bed7 100%);
}

.form-control {
    border-color: #dcdfe4;
    padding: .5rem .75rem;
    border-radius: .75rem;
}

.icones-navbar {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    transition: 0.3s;
}

.icones-navbar:hover {
    background: rgba(255, 255, 255, 0.2);
    transform: scale(1.1);
}

.politica-de-privacidade {
    padding: 5rem 18rem 2rem;
}

#toast-container {
    position: fixed;
    top: 20px;
    right: 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    z-index: 1055;
}

.toast-msg {
    min-width: 260px;
    padding: 14px 18px;
    border-radius: 12px;
    color: white;
    font-weight: 500;
    box-shadow: 0 6px 20px rgba(0,0,0,0.15);
    opacity: 0;
    transform: translateX(100%);
    animation: slideIn 0.4s forwards, fadeOut 0.5s forwards 3s;
}

.toast-success {
    background: linear-gradient(135deg, #4caf50, #2e7d32);
}

.toast-error {
    background: linear-gradient(135deg, #f44336, #c62828);
}

@keyframes slideIn {
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes fadeOut {
    to {
        opacity: 0;
        transform: translateX(100%);
    }
}

@media (min-width: 1900px) {
    .px-10 {
        padding-right: 16rem !important;
        padding-left: 16rem !important;
    }

    .navbar-custom {
        padding: 0.5rem 16rem !important;
    }

    .section-codigo-de-autenticidade {
        padding: 4rem 32rem !important;
    }

    .section-equipamentos-utilizados {
        padding: 5rem 32rem !important;
    }

    .section-nossa-tecnologia {
        padding: 6rem 18rem !important;
    }

    .section-projetos-e-eventos {
        padding: 6rem 18rem !important;
    }

    .section-contato {
        padding: 6rem 22rem !important;
    }
}

@media (max-width: 1024px) {
    .w-md-75 {
        width: 100% !important;
    }

    .px-10 {
        padding-right: 2rem !important;
        padding-left: 2rem !important;
    }

    .w-60 {
        width: 100% !important;
    }

    .section-codigo-de-autenticidade {
        padding-left: 5rem !important;
        padding-right: 5rem !important;
    }

    .section-equipamentos-utilizados {
        padding: 4rem 4rem !important;
    }

    .section-nossa-tecnologia {
        padding: 6rem 2rem !important;
    }

    .section-projetos-e-eventos {
        padding: 4rem 2rem !important;
    }
    
    .section-contato {
        padding: 6rem 1.8rem !important;
    }

    .politica-de-privacidade {
        padding: 5rem 8rem 2rem;
    }
}

@media (max-width: 768px) {
    .titulo-home {
        font-size: 3rem !important;
    }
    
    .f-48 {
        font-size: 2.25rem !important;
    }
    
    .navbar-custom {
        padding: 0.5rem 0.5rem !important;
    }

    .w-45 {
        width: 65% !important;
    }

    .section-codigo-de-autenticidade {
        padding-left: 1.5rem !important;
        padding-right: 1.5rem !important;
    }

    .section-equipamentos-utilizados {
        padding: 4rem 1.5rem !important;
    }

    .img-sm-fluid {
        max-width: 100%;
        height: auto;
    }

    .section-nossa-tecnologia {
        padding: 6rem 1.5rem !important;
    }

    .section-contato {
        padding: 6rem 1rem !important;
    }

    .politica-de-privacidade {
        padding: 5rem 2rem 2rem;
    }
}

@media (max-width: 426px) {
    .titulo-home {
        font-size: 2.25rem !important;
    }
    

    .f-36 {
        font-size: 1.875rem !important;
    }

    .f-48 {
        font-size: 1.875rem !important;
    }
    
    .navbar-custom {
        padding: 0.5rem 0.1rem !important;
    }

    .px-10 {
        padding-right: 1.2rem !important;
        padding-left: 1.2rem !important;
    }

    .w-45 {
        width: 100% !important;
    }

    .descricao-home {
        font-size: 1.125rem !important;
    }

    .section-codigo-de-autenticidade {
        padding-left: 0.5rem !important;
        padding-right: 0.5rem !important;
    }

    .section-nossa-tecnologia {
        padding: 6rem 1rem !important;
    }

    .politica-de-privacidade {
        padding: 5rem 1rem 2rem;
    }
}

