/* NOVA PALETA BASEADA EM LARANJA E BRANCO (estilo Palette B) */
:root {
    /* Cores Primárias (Laranja) - Mapeando de Palette B */
    --primary-color: #F57C00;           /* Era azul, agora Laranja Principal (de --primary-orange) */
    --primary-color-darker: #E65100;    /* Era azul escuro, agora Laranja Escuro (de --primary-orange-dark) */
    --primary-color-lighter: #FFA726;   /* Era azul claro, agora Laranja Claro (de --primary-orange-light) */
    --primary-color-rgb: 245, 124, 0;   /* Adicionado para consistência com Palette B */

    /* Cores Secundárias (Usaremos tons de laranja ou neutros como acento, já que Palette B foca no laranja) */
    --secondary-color: #FFB74D;         /* Era dourado, agora um laranja mais suave (de --card-gradient-3 ou similar) */
    --secondary-color-dark: #FFA726;    /* Era dourado escuro, agora Laranja Claro (como um "dourado" mais intenso) */
    --secondary-color-light: #FFDAB9;   /* Era dourado claro, agora um Pêssego/Laranja bem claro (PeachPuff) */
    
    /* Cores de Texto - Mapeando de Palette B */
    --text-color-dark: #212529;         /* Quase preto (de --text-primary de Palette B) */
    --text-color-light: #FFFFFF;        /* Branco puro (de --text-on-primary ou --neutral-white de Palette B) */
    --text-color-medium: #555B6E;       /* Cinza azulado sutil (de --text-secondary de Palette B) */
    --text-color-muted: #BDBDBD;        /* Cinza claro para texto sutil (de --neutral-dark-gray de Palette B) */

    /* Cores de Fundo (Light Mode) - Mapeando de Palette B */
    --bg-light-primary: #F8F9FA;        /* Fundo principal da página (de --body-bg / --neutral-light-gray de Palette B) */
    --bg-light-secondary: #FFFFFF;      /* Fundo de painéis, cards (de --content-panel-bg / --card-bg / --neutral-white de Palette B) */
    
    /* Cores de Fundo (Dark Mode) - Definindo para um tema escuro elegante */
    --bg-dark-primary: #1A1B1E;         /* Azul muito escuro -> Cinza carvão escuro para fundo principal no modo escuro */
    --bg-dark-secondary: #2C2D30;       /* Azul um pouco mais claro -> Cinza escuro para cards/painéis no modo escuro */
    
    --bg-accent-gradient: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-color-lighter) 100%); /* Mantém a lógica, mas usa as novas cores laranja */

    /* Cores de Borda - Mapeando de Palette B e definindo para Dark Mode */
    --border-color-light: #E0E0E0;      /* Cinza para bordas suaves (de --neutral-medium-gray de Palette B) */
    --border-color-dark: #3E4042;       /* Borda no modo escuro (um cinza que contrasta com --bg-dark-secondary) */

    /* Cores Semânticas */
    --danger-color: #dc3545;            /* Mantido (vermelho padrão) */
    --success-color: #28a745;           /* Verde para sucesso */
    --warning-color: #FFC107;           /* Amarelo para aviso (pode usar um laranja mais claro se preferir) */
    --info-color: #17a2b8;              /* Azul/Ciano para informação */

    /* Fontes - Mantendo suas escolhas, mas pode alinhar com Palette B se desejar */
    --font-primary: 'Poppins', sans-serif;
    --font-secondary: 'Inter', sans-serif; 
    /* Se quiser seguir Palette B:
    --font-primary: 'Inter', 'Poppins', sans-serif;
    --font-secondary: 'Poppins', 'Inter', sans-serif; 
    */

    /* Sombras - Mantendo sua estrutura, mas pode-se ajustar os RGBA para usar --primary-color-rgb para um brilho sutil da cor primária */
    --shadow-xs: 0 1px 2px rgba(0,0,0,0.04);
    --shadow-sm: 0 2px 5px rgba(var(--primary-color-rgb),0.03); /* Leve brilho laranja */
    --shadow-md: 0 5px 15px rgba(var(--primary-color-rgb),0.05); /* Leve brilho laranja */
    --shadow-lg: 0 10px 30px rgba(var(--primary-color-rgb),0.07); /* Leve brilho laranja */
    --shadow-xl: 0 20px 50px rgba(var(--primary-color-rgb),0.1);  /* Leve brilho laranja */
    
    --shadow-primary-glow: 0 0 25px rgba(var(--primary-color-rgb), 0.3); /* Usando o novo laranja */
    --shadow-secondary-glow: 0 0 20px rgba(255, 183, 77, 0.4); /* Usando --secondary-color (FFB74D) em RGBA */

    /* Border Radius - Usando os valores de Palette B para um visual mais moderno e consistente */
    --border-radius-sm: 4px;
    --border-radius-md: 6px;
    --border-radius-lg: 8px;
    --border-radius-xl: 12px;
    --border-radius-pill: 50px; /* Mantido de sua Palette A, ou use 999px para um pill mais moderno */

    /* Constantes de Layout e Transição */
    --header-height: 70px; /* Ajustado um pouco, pode manter 80px */
    --transition-speed-fast: 0.2s;
    --transition-speed-normal: 0.3s; /* Alinhado com --default-transition de Palette B */
    --transition-speed-slow: 0.5s;   /* Ajustado um pouco */
    --default-transition: all var(--transition-speed-normal) ease-in-out; /* Adicionado de Palette B */

    /* Adicionando variáveis contextuais da Palette B para referência ou uso direto */
    --sidebar-bg-ref: var(--primary-color);
    --card-bg-ref: var(--bg-light-secondary);
    --form-control-border-ref: #CED4DA; /* Cinza padrão Bootstrap, similar a --border-color-light */
    --form-control-focus-border-ref: var(--primary-color-lighter);
    --form-control-focus-shadow-ref: rgba(var(--primary-color-rgb), 0.25);
}

/* Modo Escuro */
body.dark-mode {
    /* Textos invertidos ou ajustados para fundo escuro */
    --text-color-dark: #EAECEE;          /* Era e9ecef, um branco gelo/cinza muito claro */
    --text-color-light: #343A40;         /* Era 212529, para texto escuro em elementos claros dentro do dark mode */
    --text-color-medium: #A6ACAF;        /* Era adb5bd, um cinza mais claro */
    --text-color-muted: #85929E;         /* Era 868e96, um cinza médio-claro */

    /* Fundos trocados para as versões escuras */
    --bg-light-primary: var(--bg-dark-primary);
    --bg-light-secondary: var(--bg-dark-secondary);
    
    /* Bordas trocadas para a versão escura */
    --border-color-light: var(--border-color-dark);

    /* Sombras podem precisar de ajuste para ficarem visíveis e sutis em fundos escuros */
    /* Geralmente, sombras em modo escuro são ainda mais sutis ou usam um brilho claro */
    --shadow-sm: 0 2px 5px rgba(0,0,0,0.15);
    --shadow-md: 0 5px 15px rgba(0,0,0,0.2);
    --shadow-lg: 0 10px 30px rgba(0,0,0,0.25);
    --shadow-xl: 0 20px 50px rgba(0,0,0,0.3);
    --shadow-primary-glow: 0 0 25px rgba(var(--primary-color-rgb), 0.35); /* Pode precisar de mais opacidade ou cor mais clara */
    --shadow-secondary-glow: 0 0 20px rgba(255, 183, 77, 0.45);
}

/* Reset e Globais (mantidos como estavam) */
*, *::before, *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    font-size: 16px; /* Base para REMs */
}

body {
    font-family: var(--font-secondary);
    line-height: 1.7;
    color: var(--text-color-dark);
    background-color: var(--bg-light-primary);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    transition: background-color var(--transition-speed-normal), color var(--transition-speed-normal);
    overflow-x: hidden;
}

.container {
    width: 92%;
    max-width: 1280px; /* Maior para design moderno */
    margin: 0 auto;
    padding: 0 20px;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-primary);
    color: var(--primary-color);
    font-weight: 700; /* Mais forte por padrão */
    line-height: 1.3;
    transition: color var(--transition-speed-normal);
}
body.dark-mode h1, body.dark-mode h2, body.dark-mode h3, body.dark-mode h4, body.dark-mode h5, body.dark-mode h6 {
    color: var(--secondary-color-light);
}
body.dark-mode .section-title-v2 span,
body.dark-mode .hero-title-v2 .highlight {
    color: var(--text-color-dark); /* Destaque no título em dark mode */
}


h1 { font-size: clamp(2.5rem, 5vw, 3.8rem); margin-bottom: 1.2rem; }
h2 { font-size: clamp(2rem, 4vw, 3rem); margin-bottom: 1rem; }
h3 { font-size: clamp(1.3rem, 2.5vw, 1.8rem); margin-bottom: 0.8rem; }
p { margin-bottom: 1.2rem; font-size: 1.05rem; color: var(--text-color-medium); }

a {
    text-decoration: none;
    color: var(--secondary-color);
    transition: color var(--transition-speed-fast) ease;
}
a:hover {
    color: var(--secondary-color-dark);
}
body.dark-mode a {
    color: var(--secondary-color-light);
}
body.dark-mode a:hover {
    color: var(--secondary-color);
}


img {
    max-width: 100%;
    height: auto;
    display: block;
}

.text-light { color: var(--text-color-light) !important; }
.text-light-muted { color: rgba(248, 249, 250, 0.8) !important; }
.text-left { text-align: left !important; }
.text-left-muted { color: var(--text-color-muted) !important; text-align: left !important; }
.mt-4 { margin-top: 2rem !important; }
.mt-5 { margin-top: 3.5rem !important; }
.mb-0 { margin-bottom: 0 !important; }

/* Botões Avançados */
.btn {
    display: inline-flex; /* Para alinhar ícones */
    align-items: center;
    justify-content: center;
    padding: 0.9rem 2rem;
    border-radius: var(--border-radius-pill);
    font-family: var(--font-primary);
    font-weight: 600;
    text-align: center;
    cursor: pointer;
    transition: all var(--transition-speed-normal) ease;
    border: 2px solid transparent;
    font-size: 1rem;
    position: relative;
    overflow: hidden;
    z-index: 1;
}
.btn i {
    margin-right: 0.6em;
    font-size: 1.2em;
}
.btn::before { /* Efeito de preenchimento sutil */
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 100%;
    background-color: rgba(255,255,255,0.15);
    transition: width var(--transition-speed-normal) ease;
    z-index: -1;
}
.btn:hover::before {
    width: 100%;
}

.btn-primary {
    background-color: var(--primary-color);
    color: var(--text-color-light);
    border-color: var(--primary-color);
}
.btn-primary:hover {
    background-color: var(--primary-color-lighter);
    border-color: var(--primary-color-lighter);
    transform: translateY(-3px) scale(1.02);
    box-shadow: var(--shadow-primary-glow);
}

.btn-secondary {
    background-color: var(--secondary-color);
    color: var(--primary-color-darker);
    border-color: var(--secondary-color);
}
.btn-secondary:hover {
    background-color: var(--secondary-color-dark);
    border-color: var(--secondary-color-dark);
    transform: translateY(-3px) scale(1.02);
    box-shadow: var(--shadow-secondary-glow);
}

.btn-outline-light {
    background-color: transparent;
    color: var(--text-color-light);
    border-color: var(--text-color-light);
}
.btn-outline-light:hover {
    background-color: var(--text-color-light);
    color: var(--primary-color);
    transform: translateY(-3px);
}
body.dark-mode .btn-outline-light { /* Ajuste para dark mode */
    border-color: var(--secondary-color);
    color: var(--secondary-color);
}
body.dark-mode .btn-outline-light:hover {
    background-color: var(--secondary-color);
    color: var(--bg-dark-primary);
}


.btn-lg {
    padding: 1.1rem 2.5rem;
    font-size: 1.1rem;
}
.btn-xl {
    padding: 1.3rem 3rem;
    font-size: 1.25rem;
}
.btn-header-cta-v2 {
    padding: 0.7rem 1.5rem;
    font-size: 0.9rem;
}

/* Botão Flutuante */
.floating-access-btn {
    position: fixed;
    bottom: 25px;
    right: 25px;
    background-color: var(--secondary-color);
    color: var(--primary-color-darker);
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    box-shadow: var(--shadow-lg);
    z-index: 998;
    transition: all var(--transition-speed-normal) ease;
    text-decoration: none;
}
.floating-access-btn i {
    font-size: 1.8rem;
    margin: 0;
    transition: transform var(--transition-speed-normal) ease;
}
.floating-access-btn span {
    font-size: 0.6rem;
    font-weight: 600;
    display: none; /* Mostra no hover */
    position: absolute;
    bottom: -20px;
    background-color: var(--primary-color-darker);
    color: var(--secondary-color-light);
    padding: 3px 8px;
    border-radius: var(--border-radius-sm);
    white-space: nowrap;
}
.floating-access-btn:hover {
    background-color: var(--secondary-color-dark);
    transform: translateY(-5px) scale(1.05);
    box-shadow: var(--shadow-xl), var(--shadow-secondary-glow);
}
.floating-access-btn:hover i {
    transform: rotate(10deg);
}
.floating-access-btn:hover span {
    display: block;
}


/* Header v2 */
.site-header-v2 {
    background-color: rgba(255, 255, 255, 0.85); /* Levemente transparente */
    padding: 0.8rem 0;
    box-shadow: var(--shadow-sm);
    position: fixed; /* Mudado para fixed */
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    height: var(--header-height);
    backdrop-filter: blur(10px); /* Efeito glassmorphism */
    -webkit-backdrop-filter: blur(10px);
    transition: background-color var(--transition-speed-normal), box-shadow var(--transition-speed-normal);
}
body.dark-mode .site-header-v2 {
    background-color: rgba(10, 15, 35, 0.85); /* bg-dark-primary com transparência */
}
.site-header-v2.scrolled { /* Estilo quando scrollado */
    background-color: var(--bg-light-secondary);
    box-shadow: var(--shadow-md);
}
body.dark-mode .site-header-v2.scrolled {
    background-color: var(--bg-dark-secondary);
}

.site-header-v2 .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 100%;
}
.logo-v2 {
    font-family: var(--font-primary);
    font-size: 1.9rem;
    font-weight: 800; /* Mais pesado */
    color: var(--primary-color);
    display: flex;
    align-items: center;
}
.logo-v2 .logo-img {
    height: 45px;
    width: 45px;
    margin-right: 0.7rem;
    border-radius: var(--border-radius-sm);
}
.logo-v2 span {
    color: var(--secondary-color);
    font-weight: 700;
}
body.dark-mode .logo-v2 { color: var(--text-color-dark); }
body.dark-mode .logo-v2 span { color: var(--secondary-color-light); }

.main-nav-v2 ul {
    list-style: none;
    display: flex;
}
.main-nav-v2 ul li {
    margin-left: 2.2rem;
}
.main-nav-v2 ul li a {
    color: var(--text-color-medium);
    font-weight: 600; /* Links mais fortes */
    padding: 0.6rem 0;
    position: relative;
    letter-spacing: 0.5px;
}
.main-nav-v2 ul li a::after {
    content: '';
    position: absolute;
    bottom: -2px; /* Um pouco abaixo */
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 3px; /* Mais espesso */
    background-color: var(--secondary-color);
    border-radius: 2px;
    transition: width var(--transition-speed-normal) ease;
}
.main-nav-v2 ul li a:hover,
.main-nav-v2 ul li a.active-link {
    color: var(--primary-color);
}
body.dark-mode .main-nav-v2 ul li a:hover,
body.dark-mode .main-nav-v2 ul li a.active-link {
    color: var(--secondary-color-light);
}
.main-nav-v2 ul li a:hover::after,
.main-nav-v2 ul li a.active-link::after {
    width: 60%; /* Não 100% para um look mais sutil */
}

.header-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
}

/* Dark Mode Toggle */
.dark-mode-toggle {
    background: none;
    border: 1px solid var(--border-color-light);
    color: var(--text-color-medium);
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all var(--transition-speed-fast);
    position: relative;
    overflow: hidden;
}
.dark-mode-toggle:hover {
    border-color: var(--primary-color);
    color: var(--primary-color);
}
body.dark-mode .dark-mode-toggle {
    border-color: var(--border-color-dark);
    color: var(--secondary-color-light);
}
body.dark-mode .dark-mode-toggle:hover {
    border-color: var(--secondary-color);
}

.dark-mode-toggle .icon-moon,
.dark-mode-toggle .icon-sun {
    font-size: 1.3rem;
    position: absolute;
    transition: transform var(--transition-speed-normal) ease, opacity var(--transition-speed-normal) ease;
}
.dark-mode-toggle .icon-moon { transform: translateY(0) scale(1); opacity: 1; }
.dark-mode-toggle .icon-sun { transform: translateY(20px) scale(0.5); opacity: 0; }

body.dark-mode .dark-mode-toggle .icon-moon { transform: translateY(-20px) scale(0.5); opacity: 0; }
body.dark-mode .dark-mode-toggle .icon-sun { transform: translateY(0) scale(1); opacity: 1; }


/* Mobile Nav Toggle v2 */
.mobile-nav-toggle-v2 {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.5rem;
    z-index: 1001; /* Acima do menu */
}
.mobile-nav-toggle-v2 .bar {
    display: block;
    width: 28px;
    height: 3px;
    background-color: var(--primary-color);
    margin: 5px 0;
    border-radius: 3px;
    transition: all var(--transition-speed-normal) ease-in-out;
}
body.dark-mode .mobile-nav-toggle-v2 .bar {
    background-color: var(--secondary-color-light);
}

/* Animação do Hamburguer para X */
.mobile-nav-toggle-v2.active .bar:nth-child(1) {
    transform: translateY(8px) rotate(45deg);
}
.mobile-nav-toggle-v2.active .bar:nth-child(2) {
    opacity: 0;
}
.mobile-nav-toggle-v2.active .bar:nth-child(3) {
    transform: translateY(-8px) rotate(-45deg);
}


/* Hero Section v2 */
.hero-section-v2 {
    background: var(--bg-accent-gradient);
    padding: calc(var(--header-height) + 100px) 0 100px 0; /* Espaço para header fixo */
    min-height: 100vh;
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
}
body.dark-mode .hero-section-v2 {
    background: linear-gradient(135deg, var(--bg-dark-primary) 0%, var(--bg-dark-secondary) 100%);
}

.hero-background-shapes .shape {
    position: absolute;
    border-radius: 50%;
    opacity: 0.05; /* Muito sutil */
    background-color: var(--secondary-color); /* Cor que contraste com o gradiente */
    animation: floatShape 20s infinite linear;
}
body.dark-mode .hero-background-shapes .shape {
    background-color: var(--primary-color-lighter);
    opacity: 0.1;
}
.hero-background-shapes .shape-1 { width: 300px; height: 300px; top: 10%; left: 5%; animation-duration: 25s; }
.hero-background-shapes .shape-2 { width: 200px; height: 200px; top: 60%; right: 10%; animation-duration: 18s; animation-delay: -5s; }
.hero-background-shapes .shape-3 { width: 150px; height: 150px; bottom: 15%; left: 30%; animation-duration: 22s; animation-delay: -10s; }

@keyframes floatShape {
    0% { transform: translateY(0px) translateX(0px) rotate(0deg); }
    25% { transform: translateY(-20px) translateX(15px) rotate(45deg); }
    50% { transform: translateY(10px) translateX(-10px) rotate(90deg); }
    75% { transform: translateY(-15px) translateX(20px) rotate(135deg); }
    100% { transform: translateY(0px) translateX(0px) rotate(180deg); }
}

.hero-section-v2 .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 3rem;
    position: relative;
    z-index: 2;
}
.hero-content-v2 {
    flex: 1;
    max-width: 650px;
    color: var(--text-color-light);
}
.hero-title-v2 {
    font-size: clamp(2.8rem, 6vw, 4.5rem); /* Maior e responsivo */
    font-weight: 800;
    margin-bottom: 1.8rem;
    color: var(--text-color-light);
    line-height: 1.2;
}
.hero-title-v2 .highlight {
    color: var(--secondary-color); /* Destaque diferente da cor principal */
    display: block; /* Para quebrar linha se necessário */
}
.hero-subtitle-v2 {
    font-size: 1.25rem;
    color: rgba(248, 249, 250, 0.85);
    margin-bottom: 2.8rem;
    line-height: 1.8;
}
.hero-cta-buttons {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap; /* Para mobile */
}
.hero-cta-main {
    box-shadow: var(--shadow-secondary-glow);
}
.hero-cta-alt-v2 {
    border-width: 2px; /* Mais proeminente */
}

.hero-stats {
    margin-top: 3rem;
    display: flex;
    gap: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255,255,255,0.2);
}
.stat-item {
    text-align: left;
}
.stat-number {
    display: block;
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--secondary-color);
    line-height: 1;
}
.stat-label {
    font-size: 0.9rem;
    color: rgba(248, 249, 250, 0.7);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.hero-image-area {
    flex: 0 0 45%; /* Tamanho fixo para a imagem */
    max-width: 550px;
    position: relative;
}
.hero-main-image {
    border-radius: var(--border-radius-xl);
    box-shadow: var(--shadow-xl);
    transform: perspective(1000px) rotateY(-5deg) rotateX(2deg); /* Efeito 3D sutil */
    transition: transform var(--transition-speed-slow) ease-out;
}
.hero-image-area:hover .hero-main-image {
    transform: perspective(1000px) rotateY(0deg) rotateX(0deg) scale(1.02);
}
.hero-image-deco {
    position: absolute;
    background-color: var(--secondary-color);
    border-radius: var(--border-radius-md);
    opacity: 0.6;
    z-index: -1;
}
.hero-image-deco.deco-1 { width: 100px; height: 100px; top: -30px; left: -40px; transform: rotate(15deg); }
.hero-image-deco.deco-2 { width: 150px; height: 80px; bottom: -25px; right: -50px; transform: rotate(-10deg); }


/* Seções Comuns */
.section-title-v2 {
    text-align: center;
    margin-bottom: 1rem;
    font-weight: 800;
}
.section-title-v2 span { /* Para sublinhado animado */
    display: inline-block;
    position: relative;
    padding-bottom: 0.5rem;
}
.section-title-v2 span::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 70px;
    height: 4px;
    background-color: var(--secondary-color);
    border-radius: 2px;
    transition: width var(--transition-speed-normal) ease;
}
.section-title-v2:hover span::after {
    width: 100px;
}

.section-subtitle-v2 {
    text-align: center;
    font-size: 1.15rem;
    color: var(--text-color-medium);
    max-width: 750px;
    margin: 0 auto 4rem auto; /* Mais espaço abaixo */
}

/* Features Section v2 */
.features-section-v2 {
    padding: 100px 0;
    background-color: var(--bg-light-secondary);
    position: relative;
    overflow: hidden;
}
.features-section-v2::before { /* Elemento geométrico de fundo */
    content: '';
    position: absolute;
    top: -100px;
    left: -150px;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(251,192,45,0.08) 0%, rgba(251,192,45,0) 70%);
    border-radius: 50%;
    z-index: 0;
    pointer-events: none;
}
body.dark-mode .features-section-v2::before {
    background: radial-gradient(circle, rgba(26,35,126,0.15) 0%, rgba(26,35,126,0) 70%);
}


.features-grid-v2 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 2.5rem; /* Mais espaçamento */
    position: relative;
    z-index: 1;
}
.feature-card-v2 {
    background-color: var(--bg-light-primary); /* Contraste com o fundo da seção */
    padding: 2.5rem 2rem;
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-md);
    transition: transform var(--transition-speed-normal) ease, box-shadow var(--transition-speed-normal) ease;
    position: relative;
    overflow: hidden;
    border: 1px solid var(--border-color-light);
}
.feature-card-v2:hover {
    transform: translateY(-12px) scale(1.02);
    box-shadow: var(--shadow-xl);
    border-color: var(--primary-color);
}
body.dark-mode .feature-card-v2 {
    background-color: var(--bg-dark-secondary); /* Contraste */
    border: 1px solid var(--border-color-dark);
}
body.dark-mode .feature-card-v2:hover {
    border-color: var(--secondary-color);
}


.feature-card-icon-wrapper {
    width: 70px;
    height: 70px;
    border-radius: var(--border-radius-md);
    background-image: linear-gradient(135deg, var(--primary-color), var(--primary-color-lighter));
    color: var(--text-color-light);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.2rem;
    margin-bottom: 1.5rem;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-speed-normal) ease, background-image var(--transition-speed-normal) ease;
}
.feature-card-v2:hover .feature-card-icon-wrapper {
    transform: translateY(-5px) rotate(-10deg) scale(1.1);
    background-image: linear-gradient(135deg, var(--secondary-color), var(--secondary-color-dark));
    color: var(--primary-color-darker);
}
.feature-card-title {
    font-size: 1.4rem;
    font-weight: 700;
    margin-bottom: 0.8rem;
}
.feature-card-description {
    font-size: 0.95rem;
    color: var(--text-color-medium);
    line-height: 1.6;
    min-height: 80px; /* Para alinhar cards com descrições de tamanhos diferentes */
    margin-bottom: 1.5rem;
}
.feature-card-link {
    font-weight: 600;
    color: var(--primary-color);
    display: inline-flex;
    align-items: center;
}
.feature-card-link i {
    margin-left: 0.3em;
    transition: transform var(--transition-speed-fast) ease;
}
.feature-card-v2:hover .feature-card-link {
    color: var(--secondary-color-dark);
}
.feature-card-v2:hover .feature-card-link i {
    transform: translateX(5px);
}
body.dark-mode .feature-card-link {
    color: var(--secondary-color-light);
}
body.dark-mode .feature-card-v2:hover .feature-card-link {
    color: var(--secondary-color);
}

/* How It Works Section */
.how-it-works-section {
    padding: 100px 0;
    background-color: var(--primary-color-darker);
    color: var(--text-color-light);
    position: relative;
    overflow: hidden;
}
.how-it-works-section::before { /* Overlay pattern */
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background-image: url('data:image/svg+xml;charset=UTF-8,%3Csvg%20width%3D%2252%22%20height%3D%2226%22%20viewBox%3D%220%200%2052%2026%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill-rule%3D%22evenodd%22%3E%3Cg%20fill%3D%22%23fbc02d%22%20fill-opacity%3D%220.05%22%3E%3Cpath%20d%3D%22M10%200h1v52H10z%22%20transform%3D%22rotate(45%2026%2026)%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E');
    opacity: 0.5;
    z-index: 0;
}
.how-it-works-section .container {
    position: relative;
    z-index: 1;
}
.how-it-works-section .section-title-v2 span::after {
    background-color: var(--secondary-color-light); /* Ajuste para fundo escuro */
}

.how-it-works-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 3rem;
    margin-top: 4rem;
}
.how-it-works-step {
    text-align: center;
    padding: 2rem;
    background-color: rgba(255,255,255,0.05); /* Quase transparente */
    border-radius: var(--border-radius-lg);
    border: 1px solid rgba(255,255,255,0.1);
    transition: background-color var(--transition-speed-normal), transform var(--transition-speed-normal);
}
.how-it-works-step:hover {
    background-color: rgba(255,255,255,0.1);
    transform: translateY(-10px);
}
.step-number-container {
    position: relative;
    display: inline-block;
    margin-bottom: 2rem;
}
.step-number {
    font-size: 4rem;
    font-weight: 800;
    color: var(--secondary-color);
    line-height: 1;
    opacity: 0.3;
    position: relative;
    z-index: 1;
}
.step-icon {
    font-size: 2.5rem;
    color: var(--secondary-color-light);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
    opacity: 1;
}

.step-title {
    font-size: 1.5rem;
    color: var(--text-color-light);
    margin-bottom: 0.8rem;
}
.step-description {
    font-size: 1rem;
    color: rgba(248, 249, 250, 0.75);
    line-height: 1.7;
}

/* Why Us Section */
.why-us-section {
    padding: 100px 0;
    background-color: var(--bg-light-primary);
}
.why-us-content {
    display: flex;
    align-items: center;
    gap: 4rem;
}
.why-us-text-column {
    flex: 1;
}
.why-us-text-column .section-title-v2,
.why-us-text-column .section-subtitle-v2 {
    text-align: left;
    margin-left: 0;
    margin-right: 0;
}
.differentiators-list {
    list-style: none;
    margin-top: 2.5rem;
}
.differentiators-list li {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.8rem;
}
.differentiators-list i {
    font-size: 1.8rem;
    color: var(--secondary-color);
    margin-top: 0.2rem; /* Alinhar melhor com o texto */
}
.differentiators-list h4 {
    font-size: 1.25rem;
    margin-bottom: 0.3rem;
}
.differentiators-list p {
    font-size: 0.95rem;
    color: var(--text-color-medium);
    margin-bottom: 0;
}

.why-us-image-column {
    flex: 0 0 40%;
    max-width: 480px;
    position: relative;
}
.why-us-image-column img {
    border-radius: var(--border-radius-xl);
    box-shadow: var(--shadow-lg);
    width: 100%;
    height: auto;
    object-fit: cover;
    min-height: 500px; /* Para garantir altura */
}
.geometric-shape-bg {
    position: absolute;
    width: 120%;
    height: 110%;
    top: -5%;
    left: -10%;
    background-color: var(--secondary-color);
    opacity: 0.1;
    z-index: -1;
    border-radius: var(--border-radius-lg);
    transform: rotate(-5deg);
    pointer-events: none;
}
body.dark-mode .geometric-shape-bg {
    background-color: var(--primary-color-lighter);
}

/* Testimonials Section */
.testimonials-section {
    padding: 100px 0;
    background-color: var(--bg-light-secondary);
    position: relative;
    overflow: hidden;
}
.testimonials-section::after { /* Outro elemento de fundo */
    content: '';
    position: absolute;
    bottom: -80px;
    right: -120px;
    width: 350px;
    height: 350px;
    background: radial-gradient(circle, rgba(26,35,126,0.07) 0%, rgba(26,35,126,0) 70%);
    border-radius: 50%;
    z-index: 0;
    pointer-events: none;
}
body.dark-mode .testimonials-section::after {
     background: radial-gradient(circle, rgba(251,192,45,0.1) 0%, rgba(251,192,45,0) 70%);
}

.testimonials-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 2rem;
    margin-top: 3rem;
}
.testimonial-card {
    background-color: var(--bg-light-primary);
    padding: 2rem;
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-md);
    border: 1px solid var(--border-color-light);
    position: relative;
    display: flex;
    flex-direction: column;
    transition: transform var(--transition-speed-normal), box-shadow var(--transition-speed-normal);
}
.testimonial-card:hover {
    transform: translateY(-10px);
    box-shadow: var(--shadow-lg);
}
body.dark-mode .testimonial-card {
    background-color: var(--bg-dark-secondary);
    border-color: var(--border-color-dark);
}
.testimonial-quote-icon {
    font-size: 3rem;
    color: var(--secondary-color);
    opacity: 0.3;
    position: absolute;
    top: 1rem;
    left: 1.5rem;
}
.testimonial-text {
    font-size: 1.05rem;
    font-style: italic;
    color: var(--text-color-medium);
    margin-bottom: 1.5rem;
    flex-grow: 1; /* Para empurrar o autor para baixo */
    padding-top: 1.5rem; /* Espaço para o ícone de citação */
}
.testimonial-author {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-top: auto; /* Alinha no final */
    padding-top: 1rem;
    border-top: 1px solid var(--border-color-light);
}
.testimonial-author img {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--secondary-color);
}
.author-name {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 0.2rem;
}
.author-title {
    font-size: 0.85rem;
    color: var(--text-color-muted);
    margin-bottom: 0;
}

/* App Download Section */
.app-download-section {
    padding: 120px 0;
    background: var(--bg-accent-gradient); /* Igual ao hero */
    color: var(--text-color-light);
    position: relative;
    overflow: hidden;
}
body.dark-mode .app-download-section {
    background: linear-gradient(135deg, var(--bg-dark-primary) 0%, var(--bg-dark-secondary) 100%);
}
.app-download-bg-shape { /* Forma abstrata de fundo */
    position: absolute;
    top: 50%;
    left: 50%;
    width: 80vw;
    height: 80vw;
    max-width: 1000px;
    max-height: 1000px;
    background-color: rgba(255,255,255,0.03);
    border-radius: 45% 55% 60% 40% / 50% 40% 60% 50%; /* Forma orgânica */
    transform: translate(-50%, -50%) rotate(15deg);
    animation: morphShape 15s infinite alternate ease-in-out;
    pointer-events: none;
}
@keyframes morphShape {
    0% { border-radius: 45% 55% 60% 40% / 50% 40% 60% 50%; transform: translate(-50%, -50%) rotate(15deg) scale(1); }
    100% { border-radius: 60% 40% 50% 50% / 40% 60% 50% 50%; transform: translate(-50%, -50%) rotate(-10deg) scale(1.1); }
}

.app-download-content {
    display: flex;
    align-items: center;
    gap: 4rem;
    position: relative;
    z-index: 1;
}
.app-mockups {
    flex: 1;
    display: flex;
    align-items: flex-end; /* Alinha mockups na base */
    gap: -2rem; /* Sobreposição sutil */
    position: relative;
}
.mockup-phone {
    width: 45%;
    max-width: 280px;
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-xl);
    transform: rotate(-5deg) translateY(10px);
    z-index: 2;
}
.mockup-tablet {
    width: 65%;
    max-width: 420px;
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-lg);
    transform: rotate(3deg) translateY(-5px);
    z-index: 1;
}

.app-download-text {
    flex: 1;
}
.app-download-text .section-title-v2,
.app-download-text .section-subtitle-v2 {
    text-align: left;
    margin-left: 0;
}
.app-download-text .section-title-v2 span::after {
    background-color: var(--secondary-color);
}

.app-store-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 2rem;
    margin-bottom: 1rem;
}
.app-store-btn {
    background-color: rgba(0,0,0,0.2);
    color: var(--text-color-light);
    padding: 0.8rem 1.5rem;
    border-radius: var(--border-radius-md);
    display: flex;
    align-items: center;
    gap: 0.8rem;
    transition: background-color var(--transition-speed-fast);
    border: 1px solid rgba(255,255,255,0.2);
}
.app-store-btn:hover {
    background-color: rgba(0,0,0,0.3);
}
.app-store-btn i {
    font-size: 2rem;
}
.app-store-btn div span {
    display: block;
    font-size: 0.75rem;
    opacity: 0.8;
}
.app-store-btn div strong {
    display: block;
    font-size: 1.1rem;
    font-weight: 600;
}
.app-store-btn.disabled-link {
    opacity: 0.6;
    cursor: not-allowed;
    pointer-events: none; /* Garante que não é clicável */
}
.app-store-btn.disabled-link:hover {
    background-color: rgba(0,0,0,0.2); /* Sem mudança no hover */
}
.coming-soon-text {
    font-size: 0.9rem;
    opacity: 0.8;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.coming-soon-text i {
    color: var(--secondary-color);
}

/* FAQ Section */
.faq-section {
    padding: 100px 0;
    background-color: var(--bg-light-primary);
}
.faq-accordion {
    max-width: 800px;
    margin: 3rem auto 0 auto;
}
.faq-item {
    background-color: var(--bg-light-secondary);
    border-radius: var(--border-radius-md);
    margin-bottom: 1rem;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border-color-light);
    overflow: hidden; /* Para a animação do answer */
}
body.dark-mode .faq-item {
    background-color: var(--bg-dark-secondary);
    border-color: var(--border-color-dark);
}
.faq-question {
    width: 100%;
    background: none;
    border: none;
    padding: 1.5rem 2rem;
    text-align: left;
    font-family: var(--font-primary);
    font-size: 1.15rem;
    font-weight: 600;
    color: var(--primary-color);
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: background-color var(--transition-speed-fast);
}
body.dark-mode .faq-question { color: var(--secondary-color-light); }

.faq-question:hover {
    background-color: rgba(26,35,126,0.03);
}
body.dark-mode .faq-question:hover {
    background-color: rgba(251,192,45,0.05);
}
.faq-question i {
    font-size: 1.2rem;
    transition: transform var(--transition-speed-normal) ease;
}
.faq-item.active .faq-question i {
    transform: rotate(180deg);
}
.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height var(--transition-speed-normal) ease-out, padding var(--transition-speed-normal) ease-out;
}
.faq-answer p {
    padding: 0 2rem 1.5rem 2rem;
    font-size: 1rem;
    color: var(--text-color-medium);
    margin-bottom: 0;
    line-height: 1.8;
}
.faq-item.active .faq-answer {
    /* max-height será definido via JS para acomodar conteúdo dinâmico */
}


/* Final CTA Section v2 */
.cta-final-section-v2 {
    padding: 80px 0;
    background-image: url('https://www.transparenttextures.com/patterns/diagonal-squares.png'), linear-gradient(45deg, var(--secondary-color-dark) 0%, var(--secondary-color) 100%);
    background-blend-mode: overlay;
    background-size: auto, cover;
}
.cta-content-box {
    background-color: rgba(26, 35, 126, 0.9); /* primary-color com opacidade */
    padding: 4rem;
    border-radius: var(--border-radius-xl);
    text-align: center;
    color: var(--text-color-light);
    box-shadow: var(--shadow-xl);
    position: relative;
    overflow: hidden;
}
body.dark-mode .cta-content-box {
    background-color: rgba(10, 15, 35, 0.95); /* bg-dark-primary com opacidade */
}
.cta-icon-accent {
    font-size: 4rem;
    color: var(--secondary-color);
    margin-bottom: 1.5rem;
    display: inline-block;
    animation: pulseIcon 2s infinite;
}
@keyframes pulseIcon {
    0% { transform: scale(1); }
    50% { transform: scale(1.1); }
    100% { transform: scale(1); }
}
.cta-title-v2 {
    font-size: clamp(2.2rem, 4vw, 3rem);
    color: var(--text-color-light);
    margin-bottom: 1rem;
}
.cta-text-v2 {
    font-size: 1.15rem;
    max-width: 700px;
    margin: 0 auto 2.5rem auto;
    opacity: 0.9;
}
.cta-button-v2 { /* Botão com cor primária em fundo secundário */
    background-color: var(--primary-color);
    color: var(--text-color-light);
    border-color: var(--primary-color);
}
.cta-button-v2:hover {
    background-color: var(--primary-color-lighter);
    border-color: var(--primary-color-lighter);
}
.cta-guarantee {
    margin-top: 2rem;
    font-size: 0.95rem;
    opacity: 0.8;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}
.cta-guarantee i {
    color: var(--secondary-color);
    font-size: 1.2rem;
}


/* Footer v2 - Estilo com Fundo Branco e Conteúdo Escuro */
.site-footer-v2 {
    background-color: var(--neutral-white); /* FUNDO BRANCO */
    color: var(--text-color-secondary);      /* Texto padrão: cinza escuro */
    padding: 80px 0 30px 0;
    font-size: 0.95rem;
    border-top: 1px solid var(--neutral-medium-gray); /* Adiciona uma borda superior para separar do conteúdo */
}

.footer-top {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 2.5rem;
    padding-bottom: 3rem;
    border-bottom: 1px solid var(--neutral-light-gray); /* Borda mais clara em fundo branco */
}

.footer-about .footer-logo {
    margin-bottom: 1.5rem;
    font-size: 1.8rem;
    color: var(--primary-color); /* Logo em laranja */
}

.footer-about .footer-logo .logo-img {
    height: 40px;
    width: 40px;
    /* Se o logo for um SVG que herda cor, certifique-se que ele fique visível */
    /* Se for uma imagem, ela já terá suas cores */
}

.footer-about p {
    margin-bottom: 1.5rem;
    font-size: 0.9rem;
    line-height: 1.7;
    color: var(--text-color-secondary); /* Parágrafos em cinza escuro */
}

.social-links a {
    color: var(--text-color-secondary); /* Ícones sociais em cinza escuro */
    font-size: 1.5rem;
    margin-right: 1rem;
    transition: color var(--transition-speed-fast), transform var(--transition-speed-fast);
}

.social-links a:hover {
    color: var(--primary-color); /* Hover do ícone social em laranja */
    transform: translateY(-3px);
}

.footer-links-column h4 {
    font-size: 1.2rem;
    color: var(--text-color-primary); /* Títulos das colunas em preto suave */
    margin-bottom: 1.5rem;
    font-weight: 600;
}

.footer-links-column ul {
    list-style: none;
}

.footer-links-column ul li {
    margin-bottom: 0.8rem;
}

.footer-links-column ul li a {
    color: var(--text-color-secondary); /* Links em cinza escuro */
    position: relative;
    text-decoration: none; /* Remover sublinhado padrão */
}

.footer-links-column ul li a::before {
    content: "";
    position: absolute;
    left: 0;
    bottom: -3px;
    width: 0;
    height: 1px;
    background-color: var(--primary-color); /* Sublinhado laranja no hover */
    transition: width var(--transition-speed-normal);
}

.footer-links-column ul li a:hover {
    color: var(--primary-color); /* Cor do link no hover: laranja */
}

.footer-links-column ul li a:hover::before {
    width: 100%;
}

.footer-contact p {
    margin-bottom: 0.8rem;
    display: flex;
    align-items: center;
    gap: 0.7rem;
    color: var(--text-color-secondary); /* Texto de contato em cinza escuro */
}

.footer-contact p i {
    color: var(--primary-color); /* Ícones de contato em laranja */
    font-size: 1.1rem;
}

.footer-contact p a {
    color: var(--text-color-secondary); /* Links dentro do contato em cinza escuro */
    text-decoration: none;
}

.footer-contact p a:hover {
    color: var(--primary-color); /* Hover do link de contato em laranja */
    text-decoration: underline;
}

.footer-bottom {
    padding-top: 2rem;
    text-align: center;
    font-size: 0.85rem;
    color: var(--text-color-secondary); /* Texto do rodapé final em cinza escuro */
}

.footer-bottom p {
    margin-bottom: 0.3rem;
}


/* Back to Top Button - Estilo para fundo claro (padrão) */
.back-to-top-btn {
    position: fixed;
    bottom: -60px;
    right: 25px;
    background-color: var(--primary-color);    /* Laranja */
    color: var(--neutral-white);               /* Texto branco */
    width: 45px;
    height: 45px;
    border-radius: var(--border-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--shadow-md);
    z-index: 999;
    transition: bottom var(--transition-speed-normal) ease, background-color var(--transition-speed-fast), opacity var(--transition-speed-normal) ease;
    opacity: 0;
}

.back-to-top-btn.visible {
    bottom: 25px;
    opacity: 1;
}

.back-to-top-btn i {
    font-size: 1.8rem;
    line-height: 1;
}

.back-to-top-btn:hover {
    background-color: var(--primary-color-lighter); /* Laranja mais claro no hover */
}

/* Back to Top Button - Estilo para Dark Mode (Ajuste para contraste com fundo escuro) */
/* Se o fundo da página no dark mode for escuro, o botão laranja já contrasta bem. */
/* A regra anterior o tornava secundário, o que pode não ser o ideal. */
/* Vamos mantê-lo primário (laranja) no dark mode também para consistência, a menos que haja um motivo específico. */
body.dark-mode .back-to-top-btn {
    /* Se o seu body.dark-mode tem um fundo muito escuro, o laranja padrão já funciona.
       A regra anterior o tornava --secondary-color, que definimos como laranja claro.
       Se você quer que ele se destaque mais, pode usar --primary-color.
       Se quiser que ele seja mais sutil no dark mode, pode usar um cinza escuro com ícone laranja.
       Vou manter o estilo primário (laranja) para consistência.
    */
    background-color: var(--primary-color);
    color: var(--neutral-white); /* Texto/ícone branco */
}

body.dark-mode .back-to-top-btn:hover {
    background-color: var(--primary-color-lighter);
}


/* Animações de Entrada (Scroll Reveal) */
[data-animate] {
    opacity: 0;
    transition-property: opacity, transform;
    transition-duration: 0.8s; /* Duração padrão */
    transition-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275); /* Easing com "bounce" */
}
[data-animate="fade-in"] { transform: translateY(0); }
[data-animate="fade-in-up"] { transform: translateY(50px); }
[data-animate="fade-in-down"] { transform: translateY(-50px); }
[data-animate="fade-in-left"] { transform: translateX(50px); }
[data-animate="fade-in-right"] { transform: translateX(-50px); }
[data-animate="zoom-in"] { transform: scale(0.9); }

[data-animate].is-visible {
    opacity: 1;
    transform: translateY(0) translateX(0) scale(1);
}

/* Responsividade */
@media (max-width: 1024px) {
    .hero-section-v2 .container,
    .why-us-content,
    .app-download-content {
        flex-direction: column;
        text-align: center;
    }
    .hero-content-v2, .why-us-text-column, .app-download-text {
        max-width: 100%;
    }
    .hero-image-area, .why-us-image-column, .app-mockups {
        margin: 2rem auto 0 auto;
        max-width: 80%;
    }
    .hero-stats, .hero-cta-buttons {
        justify-content: center;
    }
    .why-us-text-column .section-title-v2,
    .why-us-text-column .section-subtitle-v2,
    .app-download-text .section-title-v2,
    .app-download-text .section-subtitle-v2 {
        text-align: center;
    }
    .app-mockups {
        flex-direction: column;
        align-items: center;
        gap: 2rem;
    }
    .mockup-phone, .mockup-tablet {
        transform: rotate(0) translateY(0);
        width: 60%;
    }
}

@media (max-width: 768px) {
    html { font-size: 15px; }
    :root { --header-height: 70px; }

    .main-nav-v2 {
        display: none;
        position: fixed;
        top: 0; /* Cobre toda a tela */
        left: 0;
        width: 100%;
        height: 100vh;
        background-color: var(--bg-light-secondary);
        padding-top: calc(var(--header-height) + 2rem);
        overflow-y: auto;
        transform: translateX(100%);
        transition: transform var(--transition-speed-normal) ease-in-out;
        z-index: 999; /* Abaixo do toggle */
    }
    body.dark-mode .main-nav-v2 {
        background-color: var(--bg-dark-secondary);
    }
    .main-nav-v2.active {
        display: block;
        transform: translateX(0);
    }
    .main-nav-v2 ul {
        flex-direction: column;
        align-items: center;
        padding: 2rem 0;
    }
    .main-nav-v2 ul li {
        margin: 0;
        width: 100%;
        text-align: center;
    }
    .main-nav-v2 ul li a {
        display: block;
        padding: 1.2rem 1rem;
        font-size: 1.3rem;
        border-bottom: 1px solid var(--border-color-light);
    }
    body.dark-mode .main-nav-v2 ul li a {
        border-bottom-color: var(--border-color-dark);
    }
    .main-nav-v2 ul li:last-child a {
        border-bottom: none;
    }
    .main-nav-v2 ul li a::after { display: none; } /* Remove sublinhado no mobile menu */

    .mobile-nav-toggle-v2 {
        display: block;
    }
    .btn-header-cta-v2 {
        display: none; /* Opcional: mover para dentro do menu mobile ou remover */
    }
    .floating-access-btn { width: 50px; height: 50px; }
    .floating-access-btn i { font-size: 1.5rem; }

    .hero-section-v2 { padding: calc(var(--header-height) + 60px) 0 60px 0; }
    .features-section-v2, .how-it-works-section, .why-us-section, .testimonials-section, .app-download-section, .faq-section, .cta-final-section-v2, .site-footer-v2 {
        padding: 80px 0;
    }
    .footer-top { grid-template-columns: 1fr; text-align: center; }
    .footer-about .social-links { justify-content: center; }
}