/* ========================================================== */
/* ARQUIVO STYLE.CSS COMPLETO E FINAL (VERSÃO OTIMIZADA)      */
/* ========================================================== */

/* 1. VARIÁVEIS E CONFIGURAÇÕES GLOBAIS */
:root {
    --primary-color: #FFD700; /* Amarelo */
    --accent-color: #4A90E2;  /* Azul */
    --light-bg-color: #F4F7FA;
    --text-color: #333;
    --heading-color: #1E2A3A;
    --white-color: #FFFFFF;
    --font-heading: 'Montserrat', sans-serif;
    --font-body: 'Lato', sans-serif;
    --rainbow-gradient: linear-gradient(135deg, #7BC6FF, #A57BFD, #FF7BAA, #FFD700, #7BFF9E);
}

/* Reset e Configurações Gerais */
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-body); color: var(--text-color); background-color: var(--white-color); line-height: 1.7; font-weight: 400; }
body.menu-open { overflow: hidden; }
.container { max-width: 1100px; margin: 0 auto; padding: 0 20px; }

/* 2. COMPONENTES REUTILIZÁVEIS */
.btn { display: inline-block; padding: 12px 28px; border-radius: 50px; text-decoration: none; font-weight: 700; transition: all .3s ease; cursor: pointer; border: 2px solid transparent; text-transform: uppercase; letter-spacing: 1px; font-size: .9em; }
/* Mantendo o botão primário amarelo do seu design original */
.btn-primary { background-color: var(--primary-color); color: var(--heading-color); box-shadow: none; }
.btn-primary:hover { background-color: #FFCA28; transform: translateY(-2px); }
.btn-secondary { background-color: var(--white-color); color: var(--heading-color); }
.btn-secondary:hover { background-color: var(--heading-color); color: var(--white-color); transform: scale(1.05); }

.section { padding: 80px 0; position: relative; overflow-x: hidden; }
.section-light { background-color: var(--light-bg-color); }
.section-title { font-family: var(--font-heading); color: var(--heading-color); font-size: 3em; margin-bottom: 25px; font-weight: 700; }
.section-subtitle { max-width: 600px; margin: -20px auto 50px; font-size: 1.1em; color: var(--text-color); }
.text-center { text-align: center; }

/* 3. HEADER E NAVEGAÇÃO */
.header { background: rgba(255, 255, 255, 0.95); padding: 10px 0; position: sticky; top: 0; z-index: 1000; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05); }
.header .container { display: flex; justify-content: space-between; align-items: center; }
.logo { display: flex; align-items: center; gap: 15px; font-family: var(--font-heading); font-weight: 700; color: var(--heading-color); text-decoration: none; font-size: 1.2em; }
.logo-img { height: 45px; width: auto; }
.nav-desktop a { color: var(--text-color); text-decoration: none; margin-left: 25px; font-weight: 600; position: relative; padding: 5px 0; font-size: .95em; transition: color .3s ease; }
.nav-desktop a:not(.btn):hover { color: var(--accent-color); }
.hamburger-menu, .nav-mobile { display: none; }

/* 4. SEÇÃO HERO */
.hero { background-color: #F4F7FA; background-image: linear-gradient(135deg, rgba(244, 247, 250, 0.8) 0%, rgba(227, 242, 253, 0.8) 100%), url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100' viewBox='0 0 100 100'%3E%3Cg fill-rule='evenodd'%3E%3Cg fill='%239C92AC' fill-opacity='0.05'%3E%3Cpath opacity='.5' d='M96 95h4v1h-4v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-4v-1h4v-9h-4v-1h4v-9h-4v-1h4v-9h-4v-1h4v-9h-4v-1h4v-9h-4v-1h4v-9h-4v-1h4v-9h-4v-1h4v-4h1v4h9v-4h1v4h9v-4h1v4h9v-4h1v4h9v-4h1v4h9v-4h1v4h9v-4h1v4h9v-4h1v4h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4Z'/%3E%3Cpath d='M6 6h4v1h-4v4h-1V6h-4V5h4V1h1v4h9V1h1v4h9V1h1v4h9V1h1v4h9V1h1v4h9V1h1v4h9V1h1v4h9V1h1v4h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4H6v-4H1v-1h4V86H1v-1h4V76H1v-1h4V66H1v-1h4V56H1v-1h4V46H1v-1h4V36H1v-1h4V26H1v-1h4V16H1v-1h4V6H1V5h5V1h1v4h9V1h1v4h9V1h1v4h9V1h1v4h9V1h1v4h9V1h1v4h9V1h1v4h9V1h1v4h9V1h1v4h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4Z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"); padding: 100px 0; text-align: center; }
.hero-content { max-width: 700px; margin: 0 auto; position: relative; z-index: 2; }
.hero h1 { font-family: var(--font-heading); font-size: 4em; color: var(--heading-color); line-height: 1.1; margin-bottom: 20px; font-weight: 700; letter-spacing: -1px; opacity: 0; animation: fadeInTitle 1.5s ease-out forwards; }
.hero p { font-size: 1.3em; margin-bottom: 35px; }
@keyframes fadeInTitle { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }

/* 5. SEÇÃO SOBRE */
.about-container { display: grid; grid-template-columns: 1fr 1.2fr; gap: 60px; align-items: center; }
.about-image img { width: 100%; height: auto; border-radius: 10px; box-shadow: -15px 15px 0px var(--primary-color); }
.about-text p { margin-bottom: 15px; font-size: 1.1em; }

/* 6. SEÇÃO DE SERVIÇOS */
.service-list { margin-top: 50px; display: flex; flex-direction: column; gap: 80px; }
.service-item { display: grid; grid-template-columns: 1fr 1.2fr; gap: 50px; align-items: center; opacity: 0; transform: translateY(30px); animation: fadeInUp 0.6s ease forwards; }
.service-item:nth-child(1) { animation-delay: 0.1s; }
.service-item:nth-child(2) { animation-delay: 0.2s; }
.service-item:nth-child(3) { animation-delay: 0.3s; }
.service-item:nth-child(4) { animation-delay: 0.4s; }
.service-item:nth-child(even) .service-item-icon-wrapper { order: 2; }
.service-item-icon-wrapper { display: flex; justify-content: center; align-items: center; }
.service-icon { width: 160px; height: 160px; border-radius: 50%; background-color: var(--white-color); box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08); transition: transform 0.4s ease, box-shadow 0.4s ease; overflow: hidden; }
.service-item:hover .service-icon { transform: scale(1.05); box-shadow: 0 15px 40px rgba(0, 0, 0, 0.12); }
.service-icon img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.service-item:hover .service-icon img { transform: scale(1.1); }
.service-item-text h3 { font-family: var(--font-heading); color: var(--heading-color); font-size: 2em; margin-bottom: 15px; font-weight: 700; }
.service-item-text p { font-size: 1.1em; line-height: 1.8; margin-bottom: 20px; }
.service-item-cta { font-weight: 700; color: var(--heading-color); text-decoration: none; transition: color 0.3s ease; }
.service-item-cta:hover { color: var(--primary-color); }
@keyframes fadeInUp { to { opacity: 1; transform: translateY(0); } }

/* 7. SEÇÃO QUALIFICAÇÕES (TIMELINE) */
.timeline { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; max-width: 900px; margin: 50px auto 0; }
.timeline-item { border-left: 3px solid var(--primary-color); padding-left: 25px; }
.timeline-item h3 { font-family: var(--font-heading); color: var(--heading-color); font-size: 1.8em; margin-bottom: 15px; font-weight: 700; }
.timeline-item ul { list-style-type: none; padding-left: 0; }
.timeline-item li { margin-bottom: 10px; }

/* 8. SEÇÃO CTA (CALL TO ACTION) */
.cta-section { padding: 80px 20px; background: var(--rainbow-gradient); background-size: 200% 200%; animation: rainbow-flow 10s ease infinite; }
.cta-section h2 { font-family: var(--font-heading); color: var(--white-color); text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.2); font-size: 2.8em; margin-bottom: 15px; font-weight: 700; }
.cta-section p { max-width: 600px; margin: 0 auto 25px; color: var(--white-color); font-size: 1.1em; }
@keyframes rainbow-flow { 0% { background-position: 0% 50% } 50% { background-position: 100% 50% } 100% { background-position: 0% 50% } }

/* 9. SEÇÃO DE CONTATO SIMPLIFICADA */
#contato { padding-bottom: 100px; }

/* 10. FOOTER - ✅ VERSÃO ATUALIZADA COM INSTAGRAM ✅ */
.footer { background: var(--light-bg-color); color: var(--heading-color); text-align: center; padding: 40px 20px; font-size: 0.9em; border-top: 1px solid #e0e0e0; }
.footer-instagram { margin-bottom: 30px; padding-bottom: 30px; border-bottom: 1px solid #ddd; }
.instagram-cta { max-width: 500px; margin: 0 auto 15px; font-size: 1.1em; line-height: 1.6; }
.instagram-link { display: inline-flex; align-items: center; gap: 8px; background-color: var(--heading-color); color: var(--white-color); padding: 10px 20px; border-radius: 50px; text-decoration: none; font-weight: 600; transition: all 0.3s ease; }
.instagram-link:hover { background-color: #000; transform: scale(1.05); }
.footer-info { opacity: 0.8; }
.footer-crp { font-size: 1.1em; margin-top: 5px; }

/* 11. RESPONSIVIDADE E MENU MOBILE */
.menu-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.5); z-index: 1005; opacity: 0; visibility: hidden; transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out; }
.menu-overlay.active { opacity: 1; visibility: visible; }
@media (max-width: 992px) {
    .nav-desktop { display: none !important; }
    .hamburger-menu { display: flex; flex-direction: column; justify-content: space-around; width: 30px; height: 24px; background: transparent; border: none; cursor: pointer; padding: 0; z-index: 1020; }
    .hamburger-menu span { width: 30px; height: 3px; background-color: var(--text-color); border-radius: 5px; transition: all 0.3s linear; transform-origin: 1px; }
    .nav-mobile { display: flex; position: fixed; top: 0; right: 0; height: 100vh; width: 70%; max-width: 300px; background-color: var(--white-color); box-shadow: -5px 0 15px rgba(0, 0, 0, 0.1); flex-direction: column; align-items: center; justify-content: center; gap: 25px; transform: translateX(100%); transition: transform 0.4s ease-in-out; z-index: 1010; }
    .nav-mobile.nav-mobile-active { transform: translateX(0); }
    .nav-mobile a { color: var(--heading-color); font-size: 1.2em; font-weight: 700; text-decoration: none; padding: 10px 0; }
}
@media (max-width: 768px) {
    .logo-text { font-size: 0.8em; }
    .logo-img { height: 40px; }
    .section-title, .hero h1, .service-item-text h3, .timeline-item h3, .cta-section h2 { font-size: 2.2em; }
    .hero h1 { font-size: 2.8em; }
    .hero p, .about-text p, .service-item-text p, .cta-section p { font-size: 1.1em; }
    .about-container, .timeline { grid-template-columns: 1fr; }
    .about-image { margin-bottom: 30px; }
    .service-item, .service-item:nth-child(even) { grid-template-columns: 1fr; text-align: center; }
    .service-item:nth-child(even) .service-item-icon-wrapper { order: 0; }
    .service-icon { width: 120px; height: 120px; margin-bottom: 20px; }
    .service-item-text h3 { font-size: 1.8em; }
}

/* 12. SEÇÃO DE TESTES PSICOLÓGICOS (ACCORDION) */
.accordion { max-width: 900px; margin: 0 auto; border-radius: 10px; overflow: hidden; box-shadow: 0 5px 25px rgba(0, 0, 0, 0.05); }
.accordion-item { border-bottom: 1px solid #e0e0e0; }
.accordion-item:last-child { border-bottom: none; }
.accordion-header { width: 100%; background-color: var(--white-color); border: none; padding: 20px 30px; font-family: var(--font-heading); font-size: 1.5em; font-weight: 700; color: var(--heading-color); text-align: left; cursor: pointer; transition: background-color 0.3s ease; display: flex; justify-content: space-between; align-items: center; }
.accordion-header:hover { background-color: var(--light-bg-color); }
.accordion-header::after { content: '+'; font-size: 2em; font-weight: 300; color: var(--accent-color); transition: transform 0.3s ease; }
.accordion-header.active::after { content: '−'; transform: rotate(180deg); }
.accordion-content { background-color: #FAFAFA; overflow: hidden; max-height: 0; transition: max-height 0.5s ease-out, padding 0.5s ease-out; padding: 0 30px; }
.test-item { padding: 25px 0; border-bottom: 1px dashed #ccc; }
.test-item:last-child { border-bottom: none; }
.test-item h3 { font-family: var(--font-body); font-size: 1.2em; font-weight: 700; color: var(--heading-color); margin-bottom: 8px; }
.test-item .test-commentary { font-style: italic; color: #555; margin-bottom: 10px; }
.test-item p { font-size: 1em; line-height: 1.6; }

/* 13. ESTILOS DA ANIMAÇÃO DO BOTÃO HAMBURGER */
.hamburger-menu.active span:nth-child(1) { transform: rotate(45deg) translate(2px, 2px); }
.hamburger-menu.active span:nth-child(2) { opacity: 0; }
.hamburger-menu.active span:nth-child(3) { transform: rotate(-45deg) translate(2px, -2px); }