/* DESIGN SYSTEM & TOKENS */
:root {
    --bg-primary: #050505;
    /* Dark gray alternating background */
    --bg-alt: #121212;
    --text-base: #FFFFFF;
    --color-accent: #FFBC42;
    --color-accent-hover: #e5a432;

    --font-regular: 'Poppins', sans-serif;
    --fw-regular: 400;
    --fw-bold: 700;
    --fw-black: 900;

    --transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* RESET & BASE */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--font-regular);
    font-weight: var(--fw-regular);
    color: var(--text-base);
    background-color: var(--bg-primary);
    line-height: 1.6;
    overflow-x: hidden;
}

/* TYPOGRAPHY */
.headline-black { font-size: 3.5rem; font-weight: var(--fw-black); line-height: 1.1; margin-bottom: 1.5rem; }
.headline-bold { font-size: 2.5rem; font-weight: var(--fw-bold); line-height: 1.2; margin-bottom: 1.5rem; }
.sub-headline { font-size: 1.25rem; font-weight: var(--fw-regular); margin-bottom: 2.5rem; opacity: 0.9; }
.text-accent { color: var(--color-accent); }
.text-center { text-align: center; }
.mb-5 { margin-bottom: 3rem; }
.mt-3 { margin-top: 1rem; }
.mt-5 { margin-top: 3rem; }

/* LAYOUT & CONTAINERS */
.container { max-width: 1140px; margin: 0 auto; padding: 6rem 3rem; }
.section-primary { background-color: var(--bg-primary); }
.section-alt { background-color: var(--bg-alt); }

/* BUTTONS */
.btn {
    display: inline-flex; justify-content: center; align-items: center;
    padding: 1rem 2.5rem; font-family: var(--font-regular); font-weight: var(--fw-bold);
    text-transform: uppercase; text-decoration: none; border-radius: 8px;
    cursor: pointer; transition: var(--transition); border: none; letter-spacing: 0.5px;
    font-size: 1.1rem;
    position: relative;
    overflow: hidden;
}
.btn::before {
    content: "";
    position: absolute;
    top: 0;
    left: -150%;
    width: 150%;
    height: 100%;
    background: linear-gradient(
        115deg,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, 0) 40%,
        rgba(255, 255, 255, 0.6) 50%,
        rgba(255, 255, 255, 0) 60%,
        rgba(255, 255, 255, 0) 100%
    );
    animation: flair-sweep 3.5s ease-in-out infinite;
    pointer-events: none;
    mix-blend-mode: overlay;
}
@keyframes flair-sweep {
    0%, 15% { transform: translateX(0); }
    85%, 100% { transform: translateX(200%); }
}
.btn-primary { background-color: var(--color-accent); color: var(--bg-alt); box-shadow: 0 4px 15px rgba(255, 188, 66, 0.3); }
.btn-primary:hover { background-color: var(--color-accent-hover); transform: translateY(-2px); }
.btn-outline { background-color: transparent; color: var(--color-accent); border: 2px solid var(--color-accent); }
.btn-outline:hover { background-color: rgba(255, 188, 66, 0.1); }
.btn-block { display: flex; width: 100%; justify-content: center; }

/* GLASSMORPHISM */
.glass-card {
    background: rgba(255, 255, 255, 0.05); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
    border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 16px; padding: 2.5rem; transition: var(--transition);
}
.glass-card:hover { border-color: rgba(255, 188, 66, 0.3); box-shadow: 0 10px 30px rgba(0,0,0,0.2); }

/* IMAGES FILTER */
.hero-image img, .hero-bg-mobile img, .card-icon img, .split-image img, .mecanismo-image img, .p-icon img, .form-bg img { filter: grayscale(100%); transition: filter 0.5s ease; }
.hero-image img:hover, .hero-image img:active,
.card-icon img:hover, .card-icon img:active,
.split-image img:hover, .split-image img:active,
.mecanismo-image img:hover, .mecanismo-image img:active,
.p-icon img:hover, .p-icon img:active { filter: grayscale(0%); }

/* HEADER */
.main-header { position: absolute; top: 0; left: 0; width: 100%; z-index: 100; }
.header-container { padding: 2rem !important; }
.logo-header { height: 60px; width: auto; max-width: 250px; object-fit: contain; }

/* HERO */
.hero-section { position: relative; min-height: 100vh; display: flex; align-items: center; background-color: var(--bg-alt); }
.hero-title { text-transform: uppercase; font-size: calc(3.5rem - 5px) !important; }
.hero-bg-mobile { display: none; }
.hero-container { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; position: relative; z-index: 2; }
.hero-image { overflow: hidden; border-radius: 20px; box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5); }
.hero-image img { width: 100%; display: block; }

/* PARA QUEM É */
.texto-apoio { font-size: 1.5rem; max-width: 800px; margin: 0 auto 4rem; }
.cards-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.card { text-align: center; }
.card-icon { width: 100px; height: 100px; border-radius: 50%; background: var(--bg-alt); margin: 0 auto 1.5rem; overflow: hidden; display: flex; justify-content: center; align-items: center; }

/* POSICIONAMENTO */
.split-container { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.split-image img { width: 100%; border-radius: 16px; box-shadow: 0 20px 40px rgba(0, 0, 0, 0.4); }
.quote-box { margin-top: 2rem; padding-left: 1.5rem; border-left: 4px solid var(--color-accent); }
.quote-text { font-size: 1.5rem; font-weight: var(--fw-bold); color: var(--color-accent); font-style: italic; }

/* MECANISMO */
.mecanismo-header { text-align: center; max-width: 900px; margin: 0 auto 4rem; }
.mecanismo-wrapper { display: flex; justify-content: space-between; align-items: center; max-width: 1100px; margin: 0 auto; position: relative; }
.mecanismo-left { width: 33%; z-index:2; display: flex; flex-direction: column; justify-content: center; }
.mecanismo-right { width: 33%; z-index:2; display: flex; flex-direction: column; justify-content: center; }
.mecanismo-image { width: 34%; text-align: center; position: relative; }
.mecanismo-image img { max-width: 100%; border-radius: 50%; box-shadow: 0 0 50px rgba(255, 188, 66, 0.3); animation: float 6s infinite ease-in-out; position:relative; z-index:2;}
.glass-bg-circle { position:absolute; top:50%; left:50%; transform:translate(-50%, -50%); width: 130%; aspect-ratio:1; background: radial-gradient(circle, rgba(255, 188, 66, 0.2) 0%, transparent 70%); z-index: 1;}
.checklist-title { font-size: 1.5rem; font-weight: var(--fw-bold); color: var(--color-accent); margin-bottom:1.5rem;}
.check-list { list-style: none; font-size: 1.35rem; font-weight: 500;}
.mecanismo-left .check-list li { margin-bottom: 2rem; display: flex; align-items: center; justify-content: flex-end; text-align: right; }
.mecanismo-right .check-list li { margin-bottom: 2rem; display: flex; align-items: center; justify-content: flex-start; text-align: left; }
.mecanismo-left .check-icon { margin-left: 1.2rem; margin-right: 0; order: 2; }
.mecanismo-right .check-icon { margin-right: 1.2rem; margin-left: 0; order: -1; }
.check-icon { color: var(--color-accent); font-weight: bold; font-size: 1.5rem; }
.promessa-box { font-size: 1.5rem; }

@keyframes float { 0% { transform: translateY(0px); } 50% { transform: translateY(-15px); } 100% { transform: translateY(0px); } }

/* AUTORIDADE */
.autoridade-bg { position: relative; background-size: cover; background-position: center; background-color: var(--bg-primary); background-blend-mode: luminosity; }
.autoridade-overlay { position:absolute; top:0; left:0; right:0; bottom:0; background: linear-gradient(90deg, var(--bg-primary) 0%, rgba(5, 5, 5, 0.8) 100%); z-index: 1; }
.numbers-grid { display: grid; grid-template-columns: repeat(4, 1fr); text-align: center; gap: 2rem; margin-bottom: 4rem; }
.number-item .headline-black { color: var(--color-accent); margin-bottom: 0.5rem; }
.number-item p { font-size: 1.1rem; text-transform: uppercase; letter-spacing: 1px; font-weight: var(--fw-bold);}
.marquee-container { width: 100%; overflow: hidden; padding: 2rem 0; border-top: 1px solid rgba(255, 255, 255, 0.1); border-bottom: 1px solid rgba(255, 255, 255, 0.1); }
.marquee-content { display: flex; white-space: nowrap; align-items: center; will-change: transform; }
.marquee-logo { height: 180px; width: auto; flex-shrink: 0; margin: 0 4rem; object-fit: contain; transition: var(--transition); }
.marquee-logo:hover { opacity: 0.8; }
@keyframes marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
.testimonials { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.t-text { font-size: 1.1rem; font-style: italic; margin-bottom: 1rem; }
.t-author { font-weight: var(--fw-bold); color: var(--color-accent); }

/* OFERTA */
.pricing-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.pricing-card { display: flex; flex-direction: column; position: relative; }
.highlight-card { border-color: var(--color-accent); transform: scale(1.05); z-index: 2; background: rgba(255, 188, 66, 0.05); }
.highlight-card:hover { transform: scale(1.05) translateY(-5px); }
.popular-badge { position: absolute; top: -15px; left: 50%; transform: translateX(-50%); background: var(--color-accent); color: var(--bg-alt); padding: 0.5rem 1.5rem; border-radius: 20px; font-weight: var(--fw-bold); font-size: 0.8rem; text-transform: uppercase; }
.p-icon { height: 100px; margin-bottom: 1.5rem; overflow: hidden; border-radius: 10px; background:var(--bg-alt); padding:0.5rem; text-align:center;}
.p-icon img { height: 100%; object-fit: contain;}
.pricing-card h3 { font-size: 1.6rem; margin-bottom: 1.5rem; color: var(--color-accent); text-align:center;}
.p-features { list-style: none; flex-grow: 1; }
.p-features li { padding: 0.8rem 0; border-bottom: 1px solid rgba(255, 255, 255, 0.1); font-size: 0.95rem;}
.p-features li:last-child { border-bottom: none; }

/* CTA FINAL */
.cta-final-section { min-height: 60vh; display: flex; align-items: center; }
.cta-final-container { text-align: center; display: flex; flex-direction: column; align-items: center; }

/* CAPTAÇÃO */
.form-section { position: relative; min-height: 100vh; display: flex; align-items: center; }
.form-bg { position: absolute; top: 0; left: 0; right: 0; bottom: 0; z-index: 1; }
.form-bg img { width: 100%; height: 100%; object-fit: cover; opacity: 0.4; transform: scaleX(-1); }
.form-container { position: relative; z-index: 2; display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; width: 100%; }
.form-wrapper { background: rgba(18, 18, 18, 0.9); }
.input-group { margin-bottom: 1.5rem; }
.input-row { display: flex; gap: 1rem; }
.w-50 { width: 50%; }
label { display: block; margin-bottom: 0.5rem; font-weight: var(--fw-bold); font-size: 0.9rem; color: #ddd; }
input, select, textarea { width: 100%; padding: 1rem; background: rgba(255, 255, 255, 0.05); border: 1px solid rgba(255, 255, 255, 0.2); border-radius: 8px; color: var(--text-base); font-family: var(--font-regular); font-size: 1rem; transition: var(--transition); }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--color-accent); background: rgba(255, 255, 255, 0.1); }
select { appearance: none; background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23FFFFFF%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E"); background-repeat: no-repeat; background-position: right 1rem top 50%; background-size: 0.65rem auto; }
select option { background: var(--bg-alt); color: var(--text-base); }

/* FOOTER */
.footer { border-top: 1px solid rgba(255, 255, 255, 0.05); padding: 4rem 0 2rem; }
.footer-container { padding: 0 3rem; display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 4rem; align-items: start; }
.footer-logo { height: 50px; width: auto; max-width: 200px; object-fit: contain; margin-bottom: 1.5rem; filter: brightness(0) invert(1); opacity: 0.8; }
.footer-copy { color: rgba(255, 255, 255, 0.4); font-size: 0.9rem; margin-top: auto; }
.footer-title { font-size: 1.2rem; font-weight: var(--fw-bold); color: var(--color-accent); margin-bottom: 1.5rem; }
.footer-nav, .footer-contact { list-style: none; }
.footer-nav li, .footer-contact li { margin-bottom: 0.8rem; }
.footer-nav a { color: var(--text-base); text-decoration: none; opacity: 0.7; transition: var(--transition); }
.footer-nav a:hover { opacity: 1; color: var(--color-accent); padding-left: 5px; }
.footer-contact li { display: flex; align-items: center; opacity: 0.8; font-size: 0.95rem; }
.contact-icon { color: var(--color-accent); margin-right: 0.8rem; font-size: 1.2rem; }

/* REVEAL CLASSES */
.reveal, .reveal-left, .reveal-right { opacity: 0; transition: all 0.8s ease-out; }
.reveal { transform: translateY(30px); }
.reveal-left { transform: translateX(-50px); }
.reveal-right { transform: translateX(50px); }
.reveal.active, .reveal-left.active, .reveal-right.active { opacity: 1; transform: translate(0); }

/* MEDIA QUERIES */

/* Tablet (768px) */
@media (max-width: 1024px) {
    .container { padding: 5rem 2.5rem; }
    .headline-black { font-size: 2.8rem; }
    .hero-title { font-size: calc(2.8rem - 5px) !important; }
    .headline-bold { font-size: 2rem; }
    .hero-container { grid-template-columns: 1fr; text-align: center; }
    .hero-image { display: none; }
    .hero-bg-mobile { display: block; position: absolute; top:0; left:0; right:0; bottom:0; z-index:1; }
    .hero-bg-mobile img { width: 100%; height: 100%; object-fit: cover; opacity: 0.5; }
    .hero-gradient-map { position:absolute; top:0; left:0; right:0; bottom:0; background: linear-gradient(to bottom, var(--bg-alt) 0%, transparent 50%, var(--bg-alt) 100%); mix-blend-mode: multiply; }
    .sub-headline { line-height: 1.8; }
    .cards-grid { grid-template-columns: 1fr 1fr; }
    .cards-grid .card:last-child { grid-column: 1 / -1; max-width: 50%; margin: 0 auto; }
    .split-container { grid-template-columns: 1fr; }
    .split-image { order: -1; }
    .split-image img { height: 400px; object-fit: cover; }
    .split-content { text-align: center; }
    .mecanismo-wrapper { flex-direction: column; }
    .mecanismo-left, .mecanismo-right { width: 100%; }
    .mecanismo-image { width: 300px; margin: 3rem auto; }
    .numbers-grid { grid-template-columns: 1fr 1fr; }
    .testimonials { grid-template-columns: 1fr; }
    .form-container { grid-template-columns: 1fr; }
    .footer-container { grid-template-columns: 1fr; gap: 3rem; text-align: center; }
    .footer-logo { margin: 0 auto 1.5rem; display: block; }
    .footer-contact li { justify-content: center; }
}

/* Smartphone (600px) */
@media (max-width: 600px) {
    .container { padding: 4rem 1.5rem; }
    .headline-black { font-size: 2.5rem; font-family: var(--font-regular); font-weight: var(--fw-black); }
    .hero-title { font-size: calc(3rem - 5px) !important; }
    .btn-cta { width: 100%; }
    .hero-bg-mobile .hero-gradient-map { background: linear-gradient(180deg, rgba(18, 18, 18, 0.2) 0%, rgba(18, 18, 18, 1) 90%); }
    .cards-grid { grid-template-columns: 1fr; }
    .cards-grid .card:last-child { max-width: 100%; }
    .split-image { display: none; } /* Ocultar imagem p/ encurtar dobra */
    .mecanismo-image { width: 200px; margin: 2rem auto; }
    .check-list li { font-size: 2rem; font-weight: var(--fw-bold); }
    .mecanismo-left .check-list li, .mecanismo-right .check-list li {
        justify-content: center;
        text-align: center;
        flex-direction: column;
        line-height: 1.2;
    }
    .mecanismo-left .check-icon, .mecanismo-right .check-icon {
        order: -1;
        margin: 0 0 0.5rem 0;
        font-size: 2.5rem;
    }
    .numbers-grid { grid-template-columns: 1fr; gap: 3rem; }
    
    /* Make logos gigantically clear on mobile */
    .marquee-logo { height: 200px; max-width: 600px; margin: 0 3rem; }

    /* Horizontal Slider specifically for pricing cards on mobile */
    .pricing-cards { overflow-x: auto; scroll-snap-type: x mandatory; display: flex; padding-bottom: 2rem; grid-template-columns: none; }
    .pricing-card { min-width: 85vw; scroll-snap-align: center; margin-right: 1.5rem; }
    .highlight-card { transform: none; }
    .highlight-card:hover { transform: translateY(-5px); }

    .input-row { flex-direction: column; gap: 0; }
    .w-50 { width: 100%; }
    input, select, textarea { padding: 1.2rem; min-height: 48px; } /* Finger touch area */
}