/* Importação da fonte Public Sans do Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Public+Sans:wght@300;400;700;900&display=swap');

/* Estilos Globais e Configurações do Tailwind */
body {
    font-family: 'Public Sans', sans-serif; /* Nova fonte principal */
    background-color: #0a0a18; /* Mantém o fundo escuro */
    color: #e0e0e0;
    scroll-behavior: smooth;
}

/* Estilizando a barra de rolagem com a nova paleta */
::-webkit-scrollbar {
    width: 8px;
}
::-webkit-scrollbar-track {
    background: #1a1a2e;
}
::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, #1d76cd, #5d2ce9);
    border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, #165f9e, #4b23c3);
}

/* Títulos principais com a nova fonte */
h1, h2, h3, h4, .text-3xl.font-bold, .text-4xl.font-bold, .text-5xl.font-bold, .text-xl.font-bold {
    font-family: 'Public Sans', sans-serif; 
    font-weight: 700; /* Ajustar peso se necessário */
}

/* Header e Navegação */
#header {
    transition: background-color 0.3s ease-in-out;
}

.header-scrolled {
    background-color: rgba(10, 10, 24, 0.85);
    backdrop-filter: blur(10px);
}

/* Cores principais da nova paleta */
:root {
    --primary-color: #1d76cd;
    --secondary-color: #fff;
}

/* Animações Globais (mantidas) */
@keyframes fadeInDown { from { opacity: 0; transform: translateY(-30px); } to { opacity: 1; transform: translateY(0); } }
.animate-fade-in-down { animation: fadeInDown 0.8s ease-out forwards; }
@keyframes fadeInUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }
.animate-fade-in-up { animation: fadeInUp 0.8s ease-out forwards; }
@keyframes slideInLeft { from { opacity: 0; transform: translateX(-50px); } to { opacity: 1; transform: translateX(0); } }
.animate-slide-in-left { animation: slideInLeft 1s ease-out forwards; }
@keyframes slideInRight { from { opacity: 0; transform: translateX(50px); } to { opacity: 1; transform: translateX(0); } }
.animate-slide-in-right { animation: slideInRight 1s ease-out forwards; }
@keyframes bounceSlow { 0%, 20%, 50%, 80%, 100% {transform: translateY(0);} 40% {transform: translateY(-10px);} 60% {transform: translateY(-5px);} }
.animate-bounce-slow { animation: bounceSlow 2s infinite 1s; }

.animation-delay-200 { animation-delay: 0.2s; }
.animation-delay-300 { animation-delay: 0.3s; }
.animation-delay-400 { animation-delay: 0.4s; }
.animation-delay-500 { animation-delay: 0.5s; }

/* Estilo para os cards de funcionalidades com a nova paleta */
.feature-card {
    background: linear-gradient(145deg, #1f1f30, #141422); /* Mantém fundo escuro do card */
    transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
 }

.feature-card.is-visible { opacity: 1; transform: translateY(0); }

.feature-card:hover {
    transform: translateY(-10px) scale(1.03);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.4), 0 0 25px var(--primary-color); /* Sombra com tom da cor secundária no hover */
}

.feature-card .icon-container {
    background: linear-gradient(145deg, var(--primary-color), var(--secondary-color));
    box-shadow: 0 0 15px rgba(93, 44, 233, 0.7);
}

/* Estilo para os botões de CTA com a nova paleta */
.cta-button {
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
    transition: transform 0.2s ease-out, background-color 0.3s, background-image 0.3s, box-shadow 0.3s;
}

.cta-button.is-visible { opacity: 1; transform: translateY(0); }

.cta-button:hover {
    transform: translateY(-3px) scale(1.05);
    box-shadow: 0 8px 25px rgba(93, 44, 233, 0.4); /* Sombra com tom da cor secundária */
}

/* Hero Section */
#hero > div {
    padding: 4rem;
}

#hero {
    background-blend-mode: overlay;
}

/* Seção Problema/Solução e Benefícios - Imagens */
#problema img, #beneficios img {
    border-radius: 0.75rem;
    box-shadow: 0 10px 25px rgba(0,0,0,0.3), 0 0 10px rgba(29, 118, 205, 0.2); /* Sombra com tom da cor primária */
    transition: transform 0.3s ease-in-out;
}

#problema img:hover, #beneficios img:hover { transform: scale(1.03); }

/* Ícones na seção de benefícios */
#beneficios ul svg {
    transition: transform 0.3s ease-in-out;
}

#beneficios ul li:hover svg { transform: scale(1.2) rotate(-10deg); }

/* Ajustes de responsividade (mantidos) */
@media (max-width: 768px) {
    #hero h1 { font-size: 2.8rem; }
    #hero p { font-size: 1.1rem; }
}

/* Textos com cores de destaque */
.text-highlight-primary {
    color: var(--primary-color);
}

.text-highlight-secondary {
    color: var(--secondary-color);
    text-shadow: 0 0 8px rgba(93, 44, 233, 0.5);
}

.text-gradient-highlight {
    background: linear-gradient(90deg, var(--primary-color), var(--secondary-color));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    display: inline-block;
}

/* Botões com gradiente */
.btn-gradient {
    background-image: linear-gradient(to right, var(--primary-color) 0%, var(--secondary-color) 51%, var(--primary-color) 100%);
    background-size: 200% auto;
    color: #0c345d !important;
    transition: background-position 0.5s;
}

.btn-gradient:hover {
    background-position: right center; /* change the direction of the change here */
}

.btn-outline-gradient {
    border: 2px solid transparent;
    background-clip: padding-box;
    -webkit-background-clip: padding-box;
    position: relative;
    color: var(--primary-color);
}

.btn-outline-gradient::before {
    content: 
otation(string);
    position: absolute;
    top: -2px; left: -2px; right: -2px; bottom: -2px;
    background: linear-gradient(to right, var(--primary-color), var(--secondary-color));
    z-index: -1;
    border-radius: inherit; /* Garante que o gradiente da borda siga o raio do botão */
}

.btn-outline-gradient:hover {
    background-image: linear-gradient(to right, var(--primary-color) 0%, var(--secondary-color) 51%, var(--primary-color) 100%);
    background-size: 200% auto;
    color: white;
    text-shadow: none;
}
.btn-outline-gradient:hover::before {
    opacity: 0; /* Esconde a borda gradiente sólida para mostrar o fundo gradiente */
}

/* Espaçamento entre seções (será aumentado conforme solicitado) */
section {
    padding-top: 6rem; /* Aumentado de py-20 (5rem) */
    padding-bottom: 6rem; /* Aumentado de py-20 (5rem) */
}

#hero {
    padding-top: 5rem; /* Manter o padding do hero, pois já tem min-h-screen e pt-20 */
    padding-bottom: 0; 
}



