﻿/* ============================================================
   EuroCuida.css — Layout fluido sem quebra de colunas
   Bootstrap 5 no <head> antes deste arquivo.
   ============================================================ */

:root {
    --ec-blue: #0055A2;
    --ec-blue-dark: #2C3A64;
    --ec-blue-alpha: rgba(44, 58, 100, 0.23);
    --ec-white: #FFFFFF;
    --ec-light-blue: #00AEDE;
}

*, *::before, *::after {
    box-sizing: border-box;
}

/* ================================================================
   CONTAINER RAIZ
   ================================================================ */
.homev2-container {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: 100vh;
    overflow-x: hidden;
}

/* ================================================================
   FUNDO AZUL
   ================================================================ */
.homev2-thq-homev2-elm {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    overflow-x: hidden;
    overflow-y: visible;
    background-color: var(--ec-blue);
    padding-bottom: clamp(20px, 3vw, 60px);
}

.homev2-thq-vector1-elm {
    position: absolute;
    top: -16px;
    left: -311px;
    width: 2541px;
    height: 1262px;
    pointer-events: none;
    z-index: 0;
    flex-shrink: 0;
}

/* Ordem visual — DOM: frame2 → menu → frame1 */
.homev2-thq-frame2-elm {
    order: 2;
    position: relative;
    z-index: 1;
}

.homev2-thq-menu-elm {
    order: 1;
    position: relative;
    z-index: 10;
}

.homev2-thq-frame1-elm2 {
    order: 3;
    position: relative;
    z-index: 1;
}

/* ================================================================
   NAVBAR
   ================================================================ */
.homev2-thq-menu-elm {
    width: 84vw;
    max-width: 1140px;
    height: clamp(48px, 7vw, 100px);
    margin-top: clamp(16px, 4vw, 56px);
    flex-shrink: 0;
    position: relative;
    background-color: var(--ec-light-blue);
    border-radius: 999px;
    overflow: hidden;
}

.homev2-thq-rectangle2-elm {
    display: none;
}

.homev2-thq-group1-elm2 {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: row;
    align-items: center;
    padding-left: clamp(52px, 9%, 110px);
    padding-right: clamp(8px, 1.5%, 16px);
    gap: clamp(4px, 2%, 48px);
    box-sizing: border-box;
    overflow: hidden;
}

.homev2-thq-image1-elm2 {
    position: absolute;
    left: clamp(10px, 2%, 28px);
    top: 50%;
    transform: translateY(-50%);
    width: clamp(28px, 5%, 52px);
    height: auto;
    object-fit: contain;
}

.homev2-thq-text-elm21,
.homev2-thq-text-elm22,
.homev2-thq-text-elm23 {
    color: #0055A2;
    font-size: clamp(9px, 1.5vw, 24px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 600;
    line-height: normal;
    text-decoration: none;
    white-space: nowrap;
    flex-shrink: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    position: static;
    top: auto;
    left: auto;
    height: auto;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
}

    .homev2-thq-text-elm21 a,
    .homev2-thq-text-elm22 a,
    .homev2-thq-text-elm23 a {
        color: inherit;
        text-decoration: none;
    }

.homev2-thq-text-elm23 {
    margin-right: auto;
}

.homev2-thq-component2-elm1 {
    position: relative;
    flex-shrink: 0;
    width: auto;
    min-width: 0;
    height: 78%;
    min-height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 clamp(14px, 2.5vw, 36px);
    background-color: #FFFFFF;
    border-radius: 999px;
    cursor: pointer;
    transition: background-color 0.2s, color 0.2s, transform 0.15s;
    white-space: nowrap;
}

    .homev2-thq-component2-elm1:hover {
        background-color: #0055A2;
        transform: translateY(-1px);
    }

        .homev2-thq-component2-elm1:hover .homev2-thq-text-elm24,
        .homev2-thq-component2-elm1:hover .homev2-thq-text-elm24 a {
            color: #FFFFFF;
        }

    .homev2-thq-component2-elm1:active {
        transform: translateY(0);
    }

.homev2-thq-rectangle1-elm2 {
    display: none;
}

.homev2-thq-text-elm24 {
    position: relative;
    z-index: 1;
    color: #0055A2;
    font-size: clamp(10px, 1.3vw, 20px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 700;
    text-align: center;
    white-space: nowrap;
    width: auto;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    transition: color 0.2s;
}

    .homev2-thq-text-elm24 a {
        color: inherit;
        text-decoration: none;
    }

/* ================================================================
   HERO
   ================================================================ */
.homev2-thq-frame2-elm {
    width: 84vw;
    max-width: 1140px;
    margin-top: clamp(16px, 3vw, 48px);
    flex-shrink: 0;
}

.homev2-thq-group2-elm {
    display: grid;
    grid-template-columns: 1fr clamp(160px, 40vw, 562px);
    grid-template-rows: auto auto auto auto;
    column-gap: clamp(10px, 2.5vw, 40px);
    align-items: start;
    width: 100%;
    height: auto;
    position: relative;
}

.homev2-thq-text-elm18 {
    grid-column: 1;
    grid-row: 1;
    position: static;
    top: auto;
    left: auto;
    height: auto;
    color: var(--ec-white);
    font-size: clamp(18px, 4.5vw, 64px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 700;
    line-height: 1.08;
    text-decoration: none;
    width: 100%;
    margin-top: 0;
}

.homev2-thq-image1-elm1 {
    grid-column: 1;
    grid-row: 2;
    position: static;
    top: auto;
    left: auto;
    display: block;
    width: 100%;
    height: auto;
    max-height: clamp(50px, 8vw, 107px);
    object-fit: contain;
    object-position: left center;
    margin-top: clamp(8px, 1.5vw, 20px);
}

.homev2-thq-group1-elm1 {
    grid-column: 1;
    grid-row: 3;
    position: static;
    top: auto;
    left: auto;
    height: auto;
    width: 100%;
    background-color: var(--ec-blue-alpha);
    display: flex;
    align-items: flex-start;
    margin-top: clamp(8px, 1.5vw, 24px);
    border-radius: clamp(8px, 1.5vw, 20px);
}

.homev2-thq-text-elm12 {
    color: var(--ec-white);
    font-size: clamp(10px, 1.2vw, 20px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 300;
    line-height: 1.5;
    padding: clamp(8px, 1.2vw, 17px) clamp(10px, 1.5vw, 27px);
    position: static;
    top: auto;
    left: auto;
    height: auto;
    width: auto;
}

.homev2-thq-text-elm13 {
    font-weight: 300;
}

.homev2-thq-text-elm14 {
    font-weight: 600;
}

.homev2-thq-text-elm15 {
    font-weight: 300;
}

.homev2-thq-text-elm16 {
    font-weight: 600;
}

.homev2-thq-termosdeuso-elm,
.homev2-thq-politicadeprivacidade-elm {
    grid-column: 1;
    grid-row: 4;
    align-self: center;
    position: static;
    top: auto;
    left: auto;
    height: auto;
    width: auto;
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: clamp(4px, 0.5vw, 8px);
    margin-top: clamp(8px, 1.2vw, 20px);
}

.homev2-thq-termosdeuso-elm {
    justify-self: start;
}

.homev2-thq-politicadeprivacidade-elm {
    justify-self: start;
    padding-left: clamp(110px, 16vw, 240px);
}

.homev2-thq-frame1-elm1 {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: clamp(4px, 0.5vw, 8px);
}

.homev2-thq-text-elm10,
.homev2-thq-text-elm11 {
    position: static;
    top: auto;
    left: auto;
    height: auto;
    width: auto;
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    gap: clamp(4px, 0.5vw, 8px);
    color: var(--ec-white);
    font-size: clamp(10px, 1.2vw, 20px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 700;
    text-align: left;
    line-height: normal;
    text-decoration: underline;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
}

.homev2-thq-arrowright1-elm1,
.homev2-thq-arrowright1-elm2 {
    display: inline-block;
    position: static;
    top: auto;
    left: auto;
    width: clamp(14px, 1.6vw, 26px);
    height: clamp(14px, 1.6vw, 26px);
    flex-shrink: 0;
    vertical-align: middle;
}

.homev2-thq-rectangle1-elm1 {
    grid-column: 2;
    grid-row: 1 / 5;
    position: static;
    top: auto;
    left: auto;
    width: 100%;
    height: 100%;
    min-height: clamp(160px, 35vw, 585px);
    object-fit: cover;
    border-radius: clamp(14px, 2.5vw, 40px);
    align-self: stretch;
}

/* ================================================================
   FRAME PRINCIPAL
   ================================================================ */
.homev2-thq-frame1-elm2 {
    width: 84vw;
    max-width: 1140px;
    margin-top: clamp(24px, 4vw, 80px);
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: clamp(16px, 3vw, 50px);
}

/* ================================================================
   CARD DE CADASTRO
   ================================================================ */
.homev2-thq-component2-elm2 {
    width: 100%;
    min-height: clamp(200px, 30vw, 480px);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: relative;
    border-radius: clamp(12px, 2vw, 28px);
    background-color: rgba(255, 255, 255, 0.20);
    padding: clamp(16px, 2.5vw, 40px);
    gap: clamp(8px, 1.2vw, 18px);
    overflow: hidden;
}

    .homev2-thq-component2-elm2 .homev2-thq-group15-elm,
    .homev2-thq-component2-elm2 .homev2-thq-text-elm25,
    .homev2-thq-component2-elm2 .homev2-thq-text-elm26,
    .homev2-thq-component2-elm2 .homev2-thq-rectangle20-elm,
    .homev2-thq-component2-elm2 .homev2-thq-rectangle21-elm,
    .homev2-thq-component2-elm2 .homev2-thq-rectangle12-elm,
    .homev2-thq-component2-elm2 .homev2-thq-text-elm27,
    .homev2-thq-component2-elm2 .homev2-thq-component2-elm3 {
        display: none;
    }

.ec-cadastro {
    width: 100%;
    max-width: 780px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(6px, 1vw, 12px);
}

.ec-cadastro__titulo {
    color: var(--ec-white);
    font-size: clamp(18px, 2.2vw, 32px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 700;
    text-align: center;
    line-height: normal;
    margin: 0;
}

.ec-cadastro__subtitulo {
    color: var(--ec-white);
    font-size: clamp(12px, 1.4vw, 22px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 400;
    text-align: center;
    line-height: normal;
    margin: 0;
}

.ec-stepper {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    width: min(340px, 55%);
}

.ec-stepper__nums {
    display: flex;
    justify-content: space-between;
    width: min(160px, 45%);
    padding: 0;
    align-self: center;
}

.ec-stepper__num {
    color: var(--ec-white);
    font-size: clamp(20px, 2.4vw, 32px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 700;
    line-height: 1;
    opacity: 1;
    transition: opacity 0.3s;
}

    .ec-stepper__num.ativo {
        opacity: 1;
    }

    .ec-stepper__num:not(.ativo) {
        opacity: 0.65;
    }

.ec-stepper__trilha {
    width: 100%;
    height: 24px;
    background: #0055A2;
    border-radius: 107px;
    padding: 4px;
    box-sizing: border-box;
    display: flex;
    align-items: center;
}

.ec-stepper__fill {
    height: 16px;
    background: #00AEDE;
    border-radius: 107px;
    width: 50%;
    flex-shrink: 0;
    transition: width 0.5s cubic-bezier(0.4,0,0.2,1);
}

/* ================================================================
   INPUTS — cor do texto alterada para #0055A2
   ================================================================ */
.ec-input {
    width: 100%;
    height: clamp(40px, 5vw, 64px);
    border-radius: 999px;
    border: none;
    background: rgba(255,255,255,0.92);
    color: #2C3A64 !important;
    font-size: clamp(14px, 1.5vw, 20px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 500 !important;
    padding: 0 clamp(16px, 2.5vw, 28px);
    outline: none;
    transition: box-shadow 0.2s;
    box-sizing: border-box;
}

    .ec-input:focus {
        box-shadow: 0 0 0 3px var(--ec-light-blue);
    }

    .ec-input::placeholder {
        color: #2C3A64 !important;
        opacity: 1 !important;
        font-weight: 500 !important;
    }

    .ec-input[readonly] {
        color: #2C3A64 !important;
        -webkit-text-fill-color: #2C3A64 !important;
    }

.ec-input-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(8px, 1.5vw, 20px);
    width: 100%;
}

.ec-check-group {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: clamp(6px, 0.8vw, 12px);
}

.ec-check-label {
    display: flex;
    align-items: center;
    gap: clamp(8px, 1vw, 14px);
    color: var(--ec-white);
    font-size: clamp(11px, 1.2vw, 16px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 400;
    cursor: pointer;
}

    .ec-check-label input[type="checkbox"] {
        appearance: none;
        -webkit-appearance: none;
        width: clamp(16px, 1.8vw, 24px);
        height: clamp(16px, 1.8vw, 24px);
        min-width: clamp(16px, 1.8vw, 24px);
        border-radius: 50%;
        border: 2px solid var(--ec-light-blue);
        background: transparent;
        flex-shrink: 0;
        cursor: pointer;
        transition: background 0.2s;
    }

        .ec-check-label input[type="checkbox"]:checked {
            background: var(--ec-light-blue);
        }

    .ec-check-label a {
        color: var(--ec-white);
        text-decoration: underline;
    }

.ec-btn-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    gap: clamp(8px, 2vw, 24px);
    margin-top: clamp(4px, 0.5vw, 8px);
}

.ec-btn-row--center {
    justify-content: center;
}

.ec-btn {
    height: clamp(40px, 5vw, 64px);
    border-radius: 999px;
    border: none;
    font-size: clamp(12px, 1.3vw, 20px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 700;
    cursor: pointer;
    transition: opacity 0.2s, transform 0.15s;
    padding: 0 clamp(20px, 3vw, 40px);
}

    .ec-btn:hover {
        opacity: 0.88;
        transform: translateY(-1px);
    }

    .ec-btn:active {
        transform: translateY(0);
    }

.ec-btn--primario {
    background: var(--ec-white);
    color: var(--ec-blue);
    border: none;
    flex: 1;
    max-width: 260px;
    transition: background 0.2s, color 0.2s, transform 0.15s;
}

    .ec-btn--primario:hover {
        background: var(--ec-blue);
        color: var(--ec-white);
        opacity: 1;
        transform: translateY(-1px);
    }

.ec-btn--secundario {
    background: var(--ec-white);
    color: var(--ec-blue);
    flex: 0 0 auto;
    min-width: clamp(80px, 12vw, 160px);
    transition: background 0.2s, color 0.2s, transform 0.15s;
}

    .ec-btn--secundario:hover {
        background: var(--ec-blue);
        color: var(--ec-white);
        opacity: 1;
        transform: translateY(-1px);
    }

.ec-etapa {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(12px, 1.8vw, 24px);
    animation: ec-fade-in 0.4s ease both;
}

#ec-etapa-1 {
    width: 60%;
}

#ec-etapa-2 {
    width: 100%;
}

@keyframes ec-fade-in {
    from {
        opacity: 0;
        transform: translateY(12px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ================================================================
   SEÇÃO FARMÁCIAS + MAPA
   ================================================================ */
.homev2-thq-component4-elm {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(8px, 1.5vw, 24px);
    position: relative;
}

/* ALTERADO: texto das farmácias centralizado */
.homev2-thq-text-elm34 {
    position: static;
    top: auto;
    left: auto;
    height: auto;
    color: var(--ec-white);
    width: 100%;
    font-size: clamp(18px, 2.2vw, 32px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 700;
    letter-spacing: -0.01em;
    text-align: center !important;
    line-height: 1.25;
    margin-bottom: 0;
}

/* Oculta elementos antigos */
.homev2-thq-farmacias-elm,
.homev2-thq-group39860-elm,
.homev2-thq-maskgroup-elm,
.homev2-thq-rectangle3585-elm,
.homev2-thq-text-elm29,
.homev2-thq-location1-elm,
.homev2-thq-rectangle3586-elm,
.homev2-thq-text-elm32,
.homev2-thq-component3-elm {
    display: none !important;
}


/* ================================================================
   CARROSSEL DE FARMÁCIAS
   ================================================================ */

/* Container com fundo branco semi-transparente e bordas arredondadas */
.ec-carrossel-container {
    width: 100%;
    background: rgba(255, 255, 255, 0.20);
    border-radius: clamp(12px, 1.8vw, 20px);
    padding: clamp(16px, 2vw, 28px) clamp(16px, 2vw, 28px) clamp(12px, 1.5vw, 20px);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(10px, 1.5vw, 18px);
}

    /* Aviso de disponibilidade */
    .ec-carrossel-container > p {
        text-align: center !important;
        font-family: 'Visby CF', 'Outfit', sans-serif;
        font-size: clamp(11px, 1.1vw, 15px);
        font-weight: 400;
        color: rgba(255,255,255,0.80);
        margin: 0;
        margin-top: calc(clamp(10px, 1.5vw, 18px) * -0.6); /* cancela parte do gap do container */
        line-height: 1.4;
    }

.ec-carrossel-wrapper {
    width: 100%;
    overflow: hidden;
}

.ec-carrossel-track {
    display: flex;
    flex-direction: row;
    gap: 14px;
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    will-change: transform;
}

.ec-carrossel-card {
    flex: 0 0 calc(25% - 11px);
    background: #fff;
    border-radius: clamp(10px, 1.2vw, 16px);
    display: flex;
    align-items: center;
    justify-content: center;
    height: clamp(80px, 10vw, 120px);
    padding: clamp(12px, 1.5vw, 20px);
    box-sizing: border-box;
    box-shadow: 0 2px 12px rgba(0,0,0,0.12);
    transition: transform 0.2s;
}

    .ec-carrossel-card:hover {
        transform: translateY(-3px);
    }

    .ec-carrossel-card img {
        width: 100%;
        height: 100%;
        object-fit: contain;
        display: block;
        pointer-events: none;
    }

/* Clone — idêntico ao card normal */
.ec-clone {
    opacity: 1;
}

/* Dots */
.ec-dots {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 6px;
}

.ec-dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    border: 2px solid rgba(255,255,255,0.70);
    background: transparent;
    cursor: pointer;
    padding: 0;
    transition: background 0.25s, width 0.3s ease, border-color 0.25s;
    display: block;
}

    .ec-dot.ativo {
        width: 24px;
        background: #00AEDE;
        border-color: #00AEDE;
    }

@media (max-width: 500px) {
    .ec-carrossel-card {
        flex: 0 0 calc(50% - 7px);
    }
}

@media (max-width: 340px) {
    .ec-carrossel-card {
        flex: 0 0 100%;
    }
}

/* ================================================================
   MAPA — painel esquerdo + Leaflet
   ================================================================ */
.ec-mapa-row {
    width: 100%;
    display: flex;
    flex-direction: row;
    align-items: stretch;
    gap: clamp(12px, 1.5vw, 20px);
    overflow: visible;
    min-height: clamp(220px, 25vw, 340px);
}

.ec-painel {
    flex: 0 0 clamp(180px, 24vw, 300px);
    background: rgba(255, 255, 255, 0.18);
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: clamp(10px, 2.5vw, 80px) clamp(12px, 2vw, 24px);
    gap: clamp(10px, 1.5vw, 18px);
    z-index: 1;
    border-radius: clamp(12px, 1.8vw, 20px);
}

.ec-painel__header {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: clamp(8px, 1vw, 14px);
}

.ec-painel__icone {
    width: clamp(28px, 4vw, 52px);
    height: auto;
    flex-shrink: 0;
}

.ec-painel__titulo {
    color: var(--ec-white);
    font-size: clamp(14px, 2vw, 28px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 700;
    line-height: 1.2;
    margin: 0;
}

/* ================================================================
   BOOTSTRAP OVERRIDE — inputs readonly/disabled
   O Bootstrap força background-color: #e9ecef e opacity: 1
   nos campos [readonly] e [disabled]. Estas regras sobrescrevem.
   ================================================================ */
.ec-input[readonly],
.ec-input:read-only,
input.ec-input[readonly],
input.ec-input:read-only,
.form-control[readonly],
#ec-cpf-2,
#ec-cpf-2[readonly],
#ec-medico-nome-display,
#ec-medico-nome-display[readonly] {
    background-color: rgba(255, 255, 255, 0.92) !important;
    background: rgba(255, 255, 255, 0.92) !important;
    color: #0055A2 !important;
    -webkit-text-fill-color: #0055A2 !important;
    opacity: 1 !important;
    cursor: default !important;
}

.ec-select-field[disabled],
select.ec-select-field[disabled],
#ec-medicamento[disabled],
#ec-medicamento:disabled {
    background-color: rgba(255, 255, 255, 0.92) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%230055A2' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right clamp(16px, 2vw, 24px) center !important;
    color: #2C3A64 !important;
    -webkit-text-fill-color: rgba(0, 85, 162, 0.45) !important;
    opacity: 1 !important;
}

.ec-painel__input {
    width: 100%;
    height: clamp(36px, 4.5vw, 52px);
    border-radius: 999px;
    border: 1.5px solid rgba(255, 255, 255, 0.5);
    background: rgba(255,255,255,0.88);
    color: #0055A2 !important;
    font-size: clamp(11px, 1.2vw, 16px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    padding: 0 clamp(12px, 1.8vw, 20px);
    outline: none;
    transition: background 0.2s, border-color 0.2s;
    box-sizing: border-box;
}

    .ec-painel__input::placeholder {
        color: rgba(0, 85, 162, 0.55) !important;
        opacity: 1 !important;
    }

    .ec-painel__input:focus {
        background: rgba(255,255,255,1);
        border-color: var(--ec-light-blue);
    }

.ec-painel__btn {
    width: 100%;
    height: clamp(36px, 4.5vw, 52px);
    border-radius: 999px;
    border: none;
    background: var(--ec-white);
    color: var(--ec-blue);
    font-size: clamp(11px, 1.2vw, 16px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 700;
    cursor: pointer;
    transition: opacity 0.2s, transform 0.15s;
}

    .ec-painel__btn:hover {
        opacity: 0.88;
        transform: translateY(-1px);
    }

    .ec-painel__btn:active {
        transform: translateY(0);
    }

.ec-painel__status {
    font-size: clamp(10px, 1vw, 14px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 400;
    color: rgba(255,255,255,0.85);
    line-height: 1.4;
    min-height: 1.4em;
    margin: 0;
}

.ec-mapa {
    /* Mobile: dimensões explícitas para o Leaflet renderizar */
    width: 100% !important;
    min-width: 0 !important;
    height: 300px !important;
    min-height: 300px !important;
    border-radius: clamp(12px, 1.8vw, 20px) !important;
    overflow: hidden !important;
    z-index: 0;
    display: block !important;
}

/* Desktop: flex ocupa o espaço restante da linha */
@media (min-width: 769px) {
    .ec-mapa {
        flex: 1 1 auto !important;
        width: 100% !important;
        height: clamp(220px, 25vw, 340px) !important;
        min-height: 220px !important;
    }
}

.ec-mapa .leaflet-container {
    width: 100% !important;
    height: 100% !important;
}

/* ── Mapa mobile: coluna, painel em cima, mapa embaixo, cards abaixo ── */
@media (max-width: 768px) {
    .ec-mapa-row {
        flex-direction: column !important;
        min-height: unset !important;
        gap: 12px !important;
    }

    .ec-painel {
        flex: none !important;
        width: 100% !important;
        padding: clamp(16px, 4vw, 24px) !important;
    }

    .ec-painel__header {
        justify-content: center;
    }

    .ec-painel__input,
    .ec-painel__btn {
        width: 100% !important;
    }

    #ecfc-wrap {
        width: 100% !important;
        margin-top: 12px !important;
    }

    #ecfc-trilho {
        flex-direction: column !important;
        overflow-x: visible !important;
        overflow-y: visible !important;
    }

    .ecfc-card {
        flex: none !important;
        width: 100% !important;
        min-width: unset !important;
    }
}

/* ================================================================
   CARROSSEL — overrides garantidos
   ================================================================ */
.ec-carrossel-container {
    width: 100% !important;
    background: rgba(255, 255, 255, 0.20) !important;
    border-radius: clamp(12px, 2vw, 28px) !important;
    padding: clamp(16px, 2vw, 28px) clamp(16px, 2vw, 28px) clamp(12px, 1.5vw, 20px) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 0 !important;
}

    .ec-carrossel-container .homev2-thq-text-elm34 {
        color: #ffffff !important;
        text-align: center !important;
        margin-bottom: clamp(10px, 1.5vw, 20px) !important;
    }

#ec-wrapper {
    width: 100% !important;
    overflow: hidden !important;
    border-radius: 12px !important;
    display: block !important;
}

#ec-carrossel-track {
    display: flex !important;
    flex-direction: row !important;
    gap: 14px !important;
    padding: 14px 0 !important;
    transition: transform 0.3s cubic-bezier(0.4,0,0.2,1) !important;
    will-change: transform !important;
}

.ec-carrossel-card {
    flex: 0 0 calc(25% - 11px) !important;
    background: #fff !important;
    border-radius: 10px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: clamp(70px, 8vw, 100px) !important;
    padding: 12px !important;
    box-sizing: border-box !important;
    box-shadow: 0 2px 10px rgba(0,0,0,.10) !important;
    flex-shrink: 0 !important;
}

    .ec-carrossel-card img {
        width: 90% !important;
        height: 100% !important;
        object-fit: contain !important;
        display: block !important;
    }

#ec-dots {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 8px !important;
    margin-top: 12px !important;
}

.ec-dot {
    width: 10px !important;
    height: 10px !important;
    border-radius: 999px !important;
    border: none !important;
    background: #D9D9D9 !important;
    cursor: pointer !important;
    padding: 0 !important;
    transition: background 0.25s, width 0.3s ease !important;
    display: block !important;
}

    .ec-dot.ativo {
        width: 28px !important;
        background: #00AEDE !important;
    }

@media(max-width:500px) {
    .ec-carrossel-card {
        flex: 0 0 calc(50% - 7px) !important;
    }
}

@media(max-width:340px) {
    .ec-carrossel-card {
        flex: 0 0 100% !important;
    }
}

/* ================================================================
   SELECTS — cor do texto alterada para #0055A2
   ================================================================ */
.ec-select-field {
    width: 100%;
    height: clamp(40px, 5vw, 64px);
    border-radius: 999px;
    border: none;
    background: rgba(255,255,255,0.92);
    color: #2C3A64 !important;
    font-size: clamp(14px, 1.5vw, 20px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 500;
    padding: 0 clamp(16px, 2.5vw, 28px);
    outline: none;
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    box-sizing: border-box;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%230055A2' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right clamp(16px, 2vw, 24px) center;
    background-color: rgba(255,255,255,0.92);
}

    .ec-select-field:disabled {
        color: rgba(0, 85, 162, 0.45) !important;
        cursor: default;
    }

    .ec-select-field option {
        color: #0055A2 !important;
        background: #fff !important;
    }

        .ec-select-field option[value=""] {
            color: rgba(0, 85, 162, 0.55) !important;
        }

/* ================================================================
   RODAPÉ
   ================================================================ */
.homev2-thq-rodapversobranca-elm {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: clamp(12px, 2vw, 20px);
    padding: clamp(16px, 2.5vw, 28px) 0 clamp(12px, 1.5vw, 20px);
    position: relative;
}

.homev2-thq-line1-elm {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 1px;
}

.homev2-thq-rodape-linha1 {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important; /* 🔥 ESSENCIAL */
    width: 100% !important;
}

.homev2-thq-group39865-elm {
    flex-shrink: 0;
    width: clamp(120px, 18vw, 260px);
}

.homev2-thq-image2-elm {
    width: 100%;
    height: auto;
    object-fit: contain;
    display: block;
}

.homev2-thq-group5-elm {
    margin-left: auto !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    text-align: right !important;
    width: 100% !important;
    max-width: 420px;
}

.homev2-thq-text-elm37 {
    color: var(--ec-white);
    font-size: clamp(11px, 1.4vw, 22px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 700;
    line-height: normal;
    white-space: nowrap;
}

.homev2-thq-text-elm38 {
    color: var(--ec-white);
    font-size: clamp(10px, 1.1vw, 18px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    align-items: flex-end !important;
    font-weight: 400;
    line-height: normal;
    margin-top: clamp(2px, 0.4vw, 6px);
    white-space: nowrap;
}

.ec-rodape-contato {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: right;
    width: 100%;
    gap: clamp(8px, 1.2vw, 20px);
    margin-top: clamp(2px, 0.4vw, 6px);
}

.ec-rodape-titulo-linha {
    display: flex;
    flex-direction: row;
    align-items: baseline;
    justify-content: space-between;
    width: 100%;
    gap: clamp(12px, 2vw, 32px);
}

.homev2-thq-text-elm39 {
    color: var(--ec-white);
    font-size: clamp(10px, 1.1vw, 18px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 400;
    line-height: normal;
    margin-top: 0;
    white-space: nowrap;
}

/* ── Linha 2: pill copyright + pill Por DLOA ── */
.homev2-thq-rodape-linha2 {
    display: flex;
    flex-direction: row;
    align-items: center;
    width: 100%;
    gap: clamp(8px, 1.5vw, 16px);
}

.homev2-thq-rectangle16-elm {
    flex: 1 1 auto;
    height: clamp(40px, 5vw, 64px);
    border-radius: 999px;
    background-color: var(--ec-white);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 clamp(16px, 3vw, 40px);
}

.homev2-thq-text-elm35 {
    color: var(--ec-blue);
    font-size: clamp(9px, 1.1vw, 18px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 700;
    line-height: normal;
    white-space: nowrap;
    text-align: center;
}

.homev2-thq-rectangle17-elm {
    flex-shrink: 0;
    width: clamp(110px, 14vw, 200px);
    height: clamp(40px, 5vw, 64px);
    border-radius: 999px;
    background-color: var(--ec-white);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: clamp(6px, 1vw, 10px);
}

.homev2-thq-text-elm36 {
    color: var(--ec-blue);
    font-size: clamp(9px, 1.1vw, 18px);
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 700;
    line-height: normal;
}

.homev2-thq-versoreduzida011-elm {
    width: clamp(48px, 6vw, 108px);
    height: auto;
    object-fit: contain;
    display: block;
}

:root {
    --dl-layout-size-large: 144px;
    --dl-layout-size-small: 48px;
    --dl-layout-space-unit: 16px;
    --dl-layout-size-medium: 96px;
    --dl-layout-size-xlarge: 192px;
    --dl-layout-size-xsmall: 16px;
    --dl-color-theme-accent1: #FFFFFF;
    --dl-color-theme-accent2: #F5D1B0;
    --dl-layout-radius-round: 50%;
    --dl-layout-size-xxlarge: 288px;
    --dl-color-theme-primary1: #BF4408;
    --dl-color-theme-primary2: #E65103;
    --dl-layout-size-maxwidth: 1400px;
    --dl-layout-radius-radius2: 2px;
    --dl-layout-radius-radius4: 4px;
    --dl-layout-radius-radius8: 8px;
    --dl-layout-space-halfunit: 8px;
    --dl-layout-space-sixunits: 96px;
    --dl-layout-space-twounits: 32px;
    --dl-color-theme-secondary1: #FFFFFF;
    --dl-color-theme-secondary2: #FBF1EB;
    --dl-layout-space-fiveunits: 80px;
    --dl-layout-space-fourunits: 64px;
    --dl-layout-space-threeunits: 48px;
    --dl-color-theme-neutral-dark: #191818;
    --dl-layout-radius-cardradius: 8px;
    --dl-color-theme-neutral-light: #FBFAF9;
    --dl-layout-radius-imageradius: 8px;
    --dl-layout-radius-inputradius: 24px;
    --dl-layout-radius-buttonradius: 24px;
    --dl-layout-space-oneandhalfunits: 24px;
}

.button {
    color: var(--dl-color-theme-neutral-dark);
    display: inline-block;
    padding: 0.5rem 1rem;
    border-color: var(--dl-color-theme-neutral-dark);
    border-width: 1px;
    border-radius: 4px;
    background-color: var(--dl-color-theme-neutral-light);
}

.input {
    color: var(--dl-color-theme-neutral-dark);
    cursor: auto;
    padding: 0.5rem 1rem;
    border-color: var(--dl-color-theme-neutral-dark);
    border-width: 1px;
    border-radius: 4px;
    background-color: var(--dl-color-theme-neutral-light);
}

.textarea {
    color: var(--dl-color-theme-neutral-dark);
    cursor: auto;
    padding: 0.5rem;
    border-color: var(--dl-color-theme-neutral-dark);
    border-width: 1px;
    border-radius: 4px;
    background-color: var(--dl-color-theme-neutral-light);
}

.list {
    width: 100%;
    margin: 1em 0px 1em 0px;
    display: block;
    padding: 0px 0px 0px 1.5rem;
    list-style-type: none;
    list-style-position: outside;
}

.list-item {
    display: list-item;
}

.teleport-show {
    display: flex !important;
    transform: none !important;
}

.thq-input {
    color: var(--dl-color-theme-neutral-dark);
    cursor: auto;
    outline: none;
    padding: 0.5rem 1rem;
    align-self: stretch;
    text-align: center;
    border-color: var(--dl-color-theme-neutral-dark);
    border-width: 1px;
    border-radius: var(--dl-layout-radius-inputradius);
    background-color: var(--dl-color-theme-neutral-light);
}

    .thq-input:focus {
        outline: 1px solid var(--dl-color-theme-primary1);
    }

.thq-button-filled {
    gap: var(--dl-layout-space-halfunit);
    fill: var(--dl-color-theme-secondary1);
    color: var(--dl-color-theme-secondary1);
    cursor: pointer;
    display: flex;
    transition: 0.3s;
    align-items: center;
    font-weight: bold;
    padding-top: var(--dl-layout-space-halfunit);
    white-space: nowrap;
    border-color: var(--dl-color-theme-primary1);
    border-width: 1px;
    padding-left: var(--dl-layout-space-oneandhalfunits);
    border-radius: var(--dl-layout-radius-buttonradius);
    padding-right: var(--dl-layout-space-oneandhalfunits);
    padding-bottom: var(--dl-layout-space-halfunit);
    justify-content: center;
    background-color: var(--dl-color-theme-primary1);
}

    .thq-button-filled:hover {
        fill: var(--dl-color-theme-secondary2);
        color: var(--dl-color-theme-secondary2);
        border-color: var(--dl-color-theme-primary2);
        background-color: var(--dl-color-theme-primary2);
    }

.thq-button-outline {
    gap: var(--dl-layout-space-halfunit);
    fill: var(--dl-color-theme-primary1);
    color: var(--dl-color-theme-primary1);
    border: 1px solid;
    cursor: pointer;
    display: flex;
    transition: 0.3s;
    align-items: center;
    font-weight: bold;
    padding-top: var(--dl-layout-space-halfunit);
    white-space: nowrap;
    border-color: var(--dl-color-theme-primary1);
    padding-left: var(--dl-layout-space-oneandhalfunits);
    border-radius: var(--dl-layout-radius-buttonradius);
    padding-right: var(--dl-layout-space-oneandhalfunits);
    padding-bottom: var(--dl-layout-space-halfunit);
    justify-content: center;
}

    .thq-button-outline:hover {
        fill: var(--dl-color-theme-secondary2);
        color: var(--dl-color-theme-secondary2);
        border-color: var(--dl-color-theme-primary2);
        background-color: var(--dl-color-theme-primary2);
    }

.thq-button-flat {
    gap: var(--dl-layout-space-halfunit);
    fill: var(--dl-color-theme-primary1);
    color: var(--dl-color-theme-primary1);
    cursor: pointer;
    display: flex;
    transition: 0.3s;
    align-items: center;
    font-weight: bold;
    padding-top: var(--dl-layout-space-halfunit);
    white-space: nowrap;
    border-color: transparent;
    border-width: 1px;
    padding-left: var(--dl-layout-space-oneandhalfunits);
    border-radius: var(--dl-layout-radius-buttonradius);
    padding-right: var(--dl-layout-space-oneandhalfunits);
    padding-bottom: var(--dl-layout-space-halfunit);
    justify-content: center;
}

    .thq-button-flat:hover {
        fill: var(--dl-color-theme-secondary1);
        color: var(--dl-color-theme-secondary1);
        border-color: var(--dl-color-theme-primary2);
        background-color: var(--dl-color-theme-primary2);
    }

.thq-heading-1 {
    font-size: 48px;
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 700;
    line-height: 1.5;
}

.thq-heading-2 {
    font-size: 35px;
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 600;
    line-height: 1.5;
}

.thq-heading-3 {
    font-size: 26px;
    font-family: 'Visby CF', 'Outfit', sans-serif;
    font-weight: 600;
    line-height: 1.5;
}

.thq-body-large {
    font-size: 18px;
    font-family: 'Visby CF', 'Outfit', sans-serif;
    line-height: 1.5;
}

.thq-body-small {
    font-size: 16px;
    font-family: 'Visby CF', 'Outfit', sans-serif;
    line-height: 1.5;
}

.thq-team-image-round {
    width: 80px;
    height: 80px;
    object-fit: cover;
    border-radius: 50%;
}

.thq-section-padding {
    width: 100%;
    display: flex;
    padding: var(--dl-layout-space-fiveunits);
    position: relative;
    align-items: center;
    flex-direction: column;
}

.thq-section-max-width {
    width: 100%;
    max-width: var(--dl-layout-size-maxwidth);
}

.thq-img-ratio-1-1 {
    width: 100%;
    object-fit: cover;
    aspect-ratio: 1/1;
    border-radius: var(--dl-layout-radius-imageradius);
}

.thq-img-ratio-16-9 {
    width: 100%;
    object-fit: cover;
    aspect-ratio: 16/9;
    border-radius: var(--dl-layout-radius-imageradius);
}

.thq-img-ratio-4-3 {
    width: 100%;
    object-fit: cover;
    aspect-ratio: 4/3;
    border-radius: var(--dl-layout-radius-imageradius);
}

.thq-img-ratio-4-6 {
    width: 100%;
    object-fit: cover;
    aspect-ratio: 4/6;
    border-radius: var(--dl-layout-radius-imageradius);
}

.thq-img-round {
    width: 100%;
    border-radius: var(--dl-layout-radius-round);
}

.thq-flex-column {
    gap: var(--dl-layout-space-twounits);
    display: flex;
    overflow: hidden;
    position: relative;
    align-items: center;
    flex-direction: column;
}

.thq-flex-row {
    gap: var(--dl-layout-space-twounits);
    display: flex;
    overflow: hidden;
    position: relative;
    align-items: center;
}

.thq-grid-6 {
    display: grid;
    grid-gap: var(--dl-layout-space-twounits);
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
}

.thq-grid-5 {
    display: grid;
    grid-gap: var(--dl-layout-space-twounits);
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
}

.thq-card {
    gap: var(--dl-layout-space-oneandhalfunits);
    display: flex;
    padding: var(--dl-layout-space-twounits);
    align-items: stretch;
    border-radius: var(--dl-layout-radius-cardradius);
    flex-direction: column;
}

.thq-box-shadow {
    box-shadow: 0px 0px 5px -2px var(--dl-color-theme-neutral-dark);
}

.thq-grid-3 {
    display: grid;
    grid-gap: var(--dl-layout-space-twounits);
    grid-template-columns: 1fr 1fr 1fr;
}

.thq-grid-4 {
    display: grid;
    grid-gap: var(--dl-layout-space-twounits);
    grid-template-columns: 1fr 1fr 1fr 1fr;
}

.thq-grid-2 {
    width: 100%;
    display: grid;
    grid-gap: var(--dl-layout-space-twounits);
    grid-template-columns: 1fr 1fr;
}

.thq-checkbox {
    width: var(--dl-layout-size-xsmall);
    height: var(--dl-layout-size-xsmall);
}

.thq-select {
    cursor: pointer;
    appearance: none;
    padding-top: var(--dl-layout-space-halfunit);
    padding-left: var(--dl-layout-space-unit);
    border-radius: var(--dl-layout-radius-inputradius);
    padding-right: var(--dl-layout-space-twounits);
    padding-bottom: var(--dl-layout-space-halfunit);
    background-color: var(--dl-color-theme-neutral-light);
    background-image: url('data:image/svg+xml;charset=US-ASCII,%3Csvg width%3D%2220%22 height%3D%2220%22 xmlns%3D%22http%3A//www.w3.org/2000/svg%22 viewBox%3D%220 0 20 20%22 fill%3D%22%23000%22%3E%3Cpath d%3D%22M4.293 7.293a1 1 0 011.414 0L10 11.586l4.293-4.293a1 1 0 111.414 1.414l-5 5a1 1 0 01-1.414 0l-5-5a1 1 0 010-1.414z%22/%3E%3C/svg%3E');
    background-repeat: no-repeat;
    background-position: right 8px center;
}

.thq-divider-horizontal {
    width: 100%;
    height: 1px;
    background-color: var(--dl-color-theme-neutral-dark);
}

.thq-icon-small {
    width: 24px;
    height: 24px;
}

.thq-button-icon {
    fill: var(--dl-color-theme-secondary1);
    padding: 3px;
    transition: 0.3s;
    border-radius: var(--dl-layout-radius-round);
}

    .thq-button-icon:hover {
        fill: var(--dl-color-theme-secondary2);
    }

.thq-icon-medium {
    width: var(--dl-layout-size-small);
    height: var(--dl-layout-size-small);
}

.thq-icon-x-small {
    width: var(--dl-layout-size-xsmall);
    height: var(--dl-layout-size-xsmall);
}

.thq-link {
    cursor: pointer;
    display: inline-block;
    overflow: hidden;
    background: linear-gradient(to right, var(--dl-color-theme-primary1) 50%, var(--dl-color-theme-neutral-dark) 50%);
    transition: background-position 300ms ease;
    font-weight: 600;
    background-clip: text;
    -webkit-background-clip: text;
    background-size: 200% 100%;
    background-position: 100%;
    -webkit-text-fill-color: transparent;
}

    .thq-link:hover {
        background-position: 0 100%;
    }

.thq-grid-auto-300 {
    display: grid;
    grid-gap: var(--dl-layout-space-oneandhalfunits);
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.thq-animated-group-vertical-reverse {
    gap: var(--dl-layout-space-unit);
    width: 100%;
    display: flex;
    animation: scroll-y 20s linear infinite;
    align-items: flex-start;
    flex-direction: column;
    justify-content: space-around;
    animation-direction: reverse;
}

.thq-animated-group-horizontal-reverse {
    gap: var(--dl-layout-space-unit);
    display: flex;
    animation: scroll-x 20s linear infinite;
    min-width: 100%;
    align-items: center;
    flex-shrink: 0;
    justify-content: space-around;
    animation-direction: reverse;
}

.thq-animated-group-vertical {
    gap: var(--dl-layout-space-unit);
    width: 100%;
    display: flex;
    animation: scroll-y 20s linear infinite;
    align-items: flex-start;
    flex-direction: column;
    justify-content: space-around;
}

.thq-animated-group-horizontal {
    gap: var(--dl-layout-space-unit);
    display: flex;
    animation: scroll-x 20s linear infinite;
    min-width: 100%;
    align-items: center;
    flex-shrink: 0;
    justify-content: space-around;
}

.thq-animated-group-container-vertical {
    gap: var(--dl-layout-space-unit);
    display: flex;
    overflow: hidden;
    flex-direction: column;
}

.thq-animated-group-container-horizontal {
    gap: var(--dl-layout-space-unit);
    display: flex;
    overflow: hidden;
}

.thq-mask-image-vertical {
    mask-image: linear-gradient(to bottom, transparent, black 1%, black 99%, transparent);
}

.thq-mask-image-horizontal {
    mask-image: linear-gradient(to right, transparent, black 1%, black 99%, transparent);
}

.thq-img-scale {
    transition: 0.3s;
}

    .thq-img-scale:hover {
        transform: scale(1.05);
    }

.thq-animated-card-bg-1 {
    width: 100%;
    height: 100%;
    transition: transform 0.3s;
    border-radius: var(--dl-layout-radius-cardradius);
    background-color: var(--dl-color-theme-accent1);
}

.thq-animated-card-bg-2 {
    transition: transform 0.3s;
    border-radius: var(--dl-layout-radius-cardradius);
    background-color: var(--dl-color-theme-accent2);
}

.thq-button-animated {
    outline: none;
    z-index: 1;
    overflow: hidden;
    position: relative;
    border-width: 2px;
}

.thq-input::placeholder {
    text-align: center;
    vertical-align: middle;
}

.thq-animated-group-container-vertical:hover div {
    animation-play-state: paused;
}

.thq-animated-group-container-horizontal:hover div {
    animation-play-state: paused;
}

.thq-animated-card-bg-2:has([data-animated="true"]:hover) {
    transform: translate3d(0px, 0px, 0px) scale3d(1, 1, 1) rotateX(0deg) rotateY(0deg) rotateZ(3deg) skew(0deg, 0deg);
}

.thq-animated-card-bg-1:has([data-animated="true"]:hover) {
    transform: translate3d(0px, 0px, 0px) scale3d(1, 1, 1) rotateX(0deg) rotateY(0deg) rotateZ(-6deg) skew(0deg, 0deg);
}

.thq-button-animated:before {
    top: 0;
    left: -20%;
    color: var(--dl-color-theme-neutral-light);
    width: 200%;
    height: 101%;
    content: "";
    z-index: 1;
    position: absolute;
    transform: scaleX(0);
    transition: transform 0.5s;
    border-radius: var(--dl-layout-radius-buttonradius);
    background-color: var(--dl-color-theme-neutral-dark);
    transform-origin: 0 0;
    transition-timing-function: cubic-bezier(0.5, 1.6, 0.4, 0.7);
}

.thq-button-animated:hover::before {
    color: var(--dl-color-theme-neutral-light);
    z-index: -1;
    transform: scaleX(1);
}

.Content {
    font-size: 16px;
    font-family: Inter;
    font-weight: 400;
    line-height: 1.15;
    text-transform: none;
    text-decoration: none;
}

@media(max-width: 991px) {
    .thq-grid-4 {
        grid-template-columns: 1fr 1fr 1fr;
    }
}

@media(max-width: 767px) {
    .thq-section-padding {
        padding: var(--dl-layout-space-threeunits);
    }

    .thq-flex-column {
        gap: var(--dl-layout-space-oneandhalfunits);
    }

    .thq-flex-row {
        gap: var(--dl-layout-space-oneandhalfunits);
    }

    .thq-grid-6 {
        grid-gap: var(--dl-layout-space-oneandhalfunits);
        grid-template-columns: 1fr 1fr 1fr;
    }

    .thq-grid-5 {
        grid-gap: var(--dl-layout-space-oneandhalfunits);
        grid-template-columns: 1fr 1fr 1fr;
    }

    .thq-card {
        padding: var(--dl-layout-space-oneandhalfunits);
    }

    .thq-grid-3 {
        grid-gap: var(--dl-layout-space-oneandhalfunits);
        grid-template-columns: 1fr 1fr;
    }

    .thq-grid-4 {
        grid-gap: var(--dl-layout-space-oneandhalfunits);
        flex-direction: row;
        grid-template-columns: 1fr 1fr;
    }

    .thq-grid-2 {
        grid-gap: var(--dl-layout-space-oneandhalfunits);
        grid-template-columns: 1fr;
    }

    .thq-img-scale {
        width: 100%;
    }
}

@media(max-width: 479px) {
    .thq-section-padding {
        padding: var(--dl-layout-space-oneandhalfunits);
    }

    .thq-flex-column {
        gap: var(--dl-layout-space-unit);
    }

    .thq-flex-row {
        gap: var(--dl-layout-space-unit);
    }

    .thq-grid-6 {
        grid-gap: var(--dl-layout-space-unit);
        grid-template-columns: 1fr 1fr;
    }

    .thq-grid-5 {
        grid-gap: var(--dl-layout-space-unit);
        grid-template-columns: 1fr 1fr;
    }

    .thq-grid-3 {
        grid-gap: var(--dl-layout-space-unit);
        align-items: center;
        grid-template-columns: 1fr;
    }

    .thq-grid-4 {
        grid-gap: var(--dl-layout-space-unit);
        align-items: center;
        flex-direction: column;
        grid-template-columns: 1fr;
    }

    .thq-grid-2 {
        grid-gap: var(--dl-layout-space-unit);
    }

    .thq-grid-auto-300 {
        grid-template-columns: 1fr;
    }
}

/* =====================================================
   FIX AUTOFILL DO BROWSER (Chrome/Edge/Safari)
   O browser injeta fundo azulado nos campos preenchidos
   automaticamente. Este override neutraliza esse efeito.
   ===================================================== */
.ec-input:-webkit-autofill,
.ec-input:-webkit-autofill:hover,
.ec-input:-webkit-autofill:focus,
.ec-input:-webkit-autofill:active,
.ec-painel__input:-webkit-autofill,
.ec-painel__input:-webkit-autofill:hover,
.ec-painel__input:-webkit-autofill:focus,
.ec-painel__input:-webkit-autofill:active,
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 1000px rgba(255, 255, 255, 0.92) inset !important;
    box-shadow: 0 0 0 1000px rgba(255, 255, 255, 0.92) inset !important;
    -webkit-text-fill-color: #0055A2 !important;
    caret-color: #0055A2;
    background-color: rgba(255, 255, 255, 0.92) !important;
    transition: background-color 99999s ease-in-out 0s;
}

.ec-select-field:-webkit-autofill,
.ec-select-field:-webkit-autofill:hover,
.ec-select-field:-webkit-autofill:focus {
    -webkit-box-shadow: 0 0 0 1000px rgba(255, 255, 255, 0.92) inset !important;
    box-shadow: 0 0 0 1000px rgba(255, 255, 255, 0.92) inset !important;
    -webkit-text-fill-color: #0055A2 !important;
}

input::placeholder {
    color: #2C3A64 !important;
}

@media (max-width: 768px) {
    .ec-input-row {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 768px) {
    .ec-input-row {
        grid-template-columns: 1fr !important;
        gap: 12px;
    }
}

.ec-menu-toggle {
    display: none;
    font-size: 24px;
    background: none;
    border: none;
    color: #0055A2;
    cursor: pointer;
}

@media (max-width: 768px) {

    .homev2-thq-group1-elm2 {
        position: absolute;
        top: 100%;
        left: 0;
        width: 100%;
        flex-direction: column;
        background: white;
        padding: 16px;
        display: none; /* escondido por padrão */
        border-radius: 16px;
    }

        .homev2-thq-group1-elm2.active {
            display: flex;
        }

    .ec-menu-toggle {
        display: block;
        position: absolute;
        right: 16px;
        top: 50%;
        transform: translateY(-50%);
    }

    /* esconder textos do menu inicialmente */
    .homev2-thq-text-elm21,
    .homev2-thq-text-elm22,
    .homev2-thq-text-elm23 {
        width: 100%;
        padding: 10px 0;
    }
}

@media (max-width: 768px) {

    .ec-input-row {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 768px) {

    .ec-input-row,
    .thq-grid-2 {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 768px) {

    .ec-input-row,
    .thq-grid-2,
    #ec-etapa-2 .thq-grid-2 {
        grid-template-columns: 1fr !important;
    }
}

.ec-input-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(8px,1.5vw,20px);
    width: 100%;
}

@media (max-width: 768px) {
    .ec-input-row {
        grid-template-columns: 1fr !important;
    }
}

.ec-input-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(8px,1.5vw,20px);
    width: 100%;
}

@media (max-width: 768px) {
    .ec-input-row {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 768px) {

    #ec-etapa-2 div[style*="grid-template-columns:1fr 1fr"] {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 768px) {

    .homev2-thq-rodape-linha1 {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 12px;
    }

    .homev2-thq-group5-elm {
        align-items: flex-start !important;
        text-align: left;
        width: 100%;
    }

    .homev2-thq-text-elm37,
    .homev2-thq-text-elm38,
    .homev2-thq-text-elm39 {
        white-space: normal !important;
    }
}

@media (max-width: 768px) {

    .ec-rodape-contato {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 4px;
    }
}

/* ========================= */
/* FIXES RESPONSIVOS (EURO CUIDA) */
/* ========================= */

/* ===== FORM MOBILE ===== */
@media (max-width: 768px) {
    .ec-input-row {
        grid-template-columns: 1fr !important;
    }
}

/* ===== RODAPÉ DESKTOP ===== */
.homev2-thq-rodape-linha1 {
    justify-content: space-between !important;
}

.homev2-thq-group5-elm {
    align-items: flex-end !important;
    text-align: right !important;
    max-width: 420px;
    width: 100%;
}

/* ===== RODAPÉ MOBILE ===== */
@media (max-width: 768px) {

    .homev2-thq-rodape-linha1 {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 12px;
    }

    .homev2-thq-group5-elm {
        align-items: flex-start !important;
        text-align: left !important;
        max-width: 100% !important;
    }

    .ec-rodape-contato {
        flex-direction: column !important;
        gap: 4px;
    }

       .homev2-thq-text-elm37,
    .homev2-thq-text-elm38,
    .homev2-thq-text-elm39,
    .homev2-thq-text-elm35 {
        white-space: normal !important;
        word-break: break-word;
    }

    .homev2-thq-rodape-linha2 {
        flex-direction: column !important;
        gap: 10px;
    }
}

/* ===================================================== */
/* FIX DEFINITIVO RODAPÉ + RESPONSIVO */
/* ===================================================== */

/* DESKTOP */
.homev2-thq-rodape-linha1 {
    justify-content: space-between !important;
}

.homev2-thq-group5-elm {
    align-items: flex-end !important;
    text-align: right !important;
    width: 100% !important;
    max-width: 420px;
}

/* 🔥 REMOVE BUG PRINCIPAL */
.homev2-thq-text-elm37,
.homev2-thq-text-elm38,
.homev2-thq-text-elm39,
.homev2-thq-text-elm35 {
    white-space: normal !important;
    word-break: break-word;
}

/* MOBILE */
@media (max-width: 768px) {

    /* Linha 1: empilha logo + bloco CAE, ambos centralizados */
    .homev2-thq-rodape-linha1 {
        flex-direction: column !important;
        align-items: center !important;
        gap: 12px !important;
    }

    .homev2-thq-group39865-elm {
        width: clamp(100px, 40vw, 180px) !important;
    }

    .homev2-thq-group5-elm {
        align-items: center !important;
        text-align: center !important;
        max-width: 100% !important;
        width: 100% !important;
    }

    .homev2-thq-text-elm37 {
        white-space: normal !important;
        overflow: visible !important;
        text-overflow: clip !important;
        font-size: clamp(15px, 4vw, 22px) !important;
        text-align: center !important;
    }

    /* Email + Tel: linha única centralizada */
    .ec-rodape-contato {
        flex-direction: row !important;
        justify-content: center !important;
        align-items: center !important;
        gap: clamp(12px, 4vw, 24px) !important;
        flex-wrap: wrap !important;
    }

    .homev2-thq-text-elm38,
    .homev2-thq-text-elm39 {
        white-space: nowrap !important;
        font-size: clamp(11px, 3vw, 15px) !important;
    }

    /* Linha 2: pílulas lado a lado (não empilhadas) */
    .homev2-thq-rodape-linha2 {
        flex-direction: row !important;
        align-items: center !important;
        gap: 10px !important;
    }

    .homev2-thq-rectangle16-elm {
        flex: 1 1 auto !important;
        min-width: 0 !important;
        height: clamp(44px, 12vw, 56px) !important;
        padding: 0 12px !important;
        overflow: hidden !important;
        box-sizing: border-box !important;
    }

    .homev2-thq-text-elm35 {
        white-space: normal !important;
        word-break: break-word !important;
        font-size: clamp(9px, 2.5vw, 10px) !important;
        text-align: center !important;
    }

    /* pílula menor (logo) */
    .homev2-thq-rectangle17-elm {
        width: auto !important;
        padding: 8px 14px !important;
        border-radius: 999px !important;
        gap: 6px !important;
    }

    .homev2-thq-text-elm36 {
        font-size: 11px !important;
    }

    .homev2-thq-versoreduzida011-elm {
        width: 44px !important;
    }
}

/* ===== MOBILE FINAL — AJUSTE PROFISSIONAL ===== */
@media (max-width: 768px) {

    /* BLOCO GERAL */
    .homev2-thq-rodapversobranca-elm {
        padding: 24px 16px !important;
    }

    /* LOGO */
    .homev2-thq-group39865-elm {
        width: 140px !important;
        margin-bottom: 8px;
    }

    /* TEXTO CAE */
    .homev2-thq-text-elm37 {
        font-size: 16px !important;
        line-height: 1.4 !important;
        text-align: center;
    }

    /* EMAIL + TEL */
    .ec-rodape-contato {
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 18px !important;
        margin-top: 8px !important;
    }

    .ec-contato-item {
        font-size: 13px;
        display: flex;
        align-items: center;
    }

    /* LINHA PÍLULAS */
    .homev2-thq-rodape-linha2 {
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 14px !important;
        margin-top: 20px !important;
    }

    /* PÍLULA GRANDE */
    .homev2-thq-rectangle16-elm {
        max-width: 260px !important;
        padding: 12px 18px !important;
    }

    .homev2-thq-text-elm35 {
        font-size: 12px !important;
        line-height: 1.4 !important;
    }

    /* PÍLULA DLOA */
    .homev2-thq-rectangle17-elm {
        padding: 8px 14px !important;
    }

    .homev2-thq-versoreduzida011-elm {
        width: 42px !important;
    }
}

/* ===== MOBILE FINAL — AJUSTE PROFISSIONAL ===== */
@media (max-width: 768px) {

    /* BLOCO GERAL */
    .homev2-thq-rodapversobranca-elm {
        padding: 24px 16px !important;
    }

    /* LOGO */
    .homev2-thq-group39865-elm {
        width: 140px !important;
        margin-bottom: 8px;
    }

    /* TEXTO CAE */
    .homev2-thq-text-elm37 {
        font-size: 16px !important;
        line-height: 1.4 !important;
        text-align: center;
    }

    /* EMAIL + TEL */
    .ec-rodape-contato {
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 18px !important;
        margin-top: 8px !important;
    }

    .ec-contato-item {
        font-size: 13px;
        display: flex;
        align-items: center;
    }

    /* LINHA PÍLULAS */
    .homev2-thq-rodape-linha2 {
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 14px !important;
        margin-top: 20px !important;
    }

    /* PÍLULA GRANDE */
    .homev2-thq-rectangle16-elm {
        max-width: 260px !important;
        padding: 12px 18px !important;
    }

    .homev2-thq-text-elm35 {
        font-size: 10px !important;
        line-height: 1.4 !important;
    }

    /* PÍLULA DLOA */
    .homev2-thq-rectangle17-elm {
        padding: 8px 14px !important;
    }

    .homev2-thq-versoreduzida011-elm {
        width: 42px !important;
    }
}

/* ================= FOOTER BASE ================= */
.ec-footer {
    width: 100%;
    color: #fff;
}

/* ================= DESKTOP ================= */
.ec-footer--desktop {
    display: block;
}

.ec-footer-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.ec-footer-logo {
    width: 180px;
}

.ec-footer-info {
    text-align: right;
}

.ec-footer-title {
    font-size: 18px;
    font-weight: 600;
}

.ec-footer-contact {
    margin-top: 6px;
    display: flex;
    gap: 12px;
    justify-content: flex-end;
}

    .ec-footer-contact a {
        color: #fff;
        text-decoration: underline;
    }

.ec-footer-bottom {
    margin-top: 20px;
    display: flex;
    justify-content: center;
    gap: 20px;
}

/* ================= MOBILE ================= */
.ec-footer--mobile {
    display: none;
}

/* ================= PILLS ================= */
.ec-pill {
    background: #fff;
    color: #0055A2;
    padding: 10px 18px;
    border-radius: 999px;
    font-size: 12px;
    text-align: center;
}

.ec-pill--logo {
    display: flex;
    align-items: center;
    gap: 6px;
}

    .ec-pill--logo img {
        width: 50px;
    }

/* ================= MOBILE LAYOUT ================= */
@media (max-width: 768px) {

    .ec-footer--desktop {
        display: none;
    }

    .ec-footer--mobile {
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        padding: 24px 16px;
        gap: 12px;
    }

    .ec-footer-logo-mobile {
        width: 140px;
    }

    .ec-footer-title-mobile {
        font-size: 18px;
        font-weight: 600;
        line-height: 1.3;
    }

    .ec-footer-contact-mobile {
        display: flex;
        gap: 16px;
        font-size: 14px;
    }

        .ec-footer-contact-mobile a {
            color: #fff;
            text-decoration: underline;
        }

    .ec-footer-pills-mobile {
        display: flex;
        gap: 12px;
        margin-top: 10px;
    }

    .ec-pill {
        font-size: 12px;
        padding: 10px 14px;
        max-width: 240px;
    }
}

@media (max-width: 768px) {

    .homev2-thq-rodape-linha1 {
        flex-direction: column !important;
        align-items: center !important;
        text-align: center !important;
        gap: 10px !important;
    }

    .homev2-thq-group5-elm {
        align-items: center !important;
        margin-left: 0 !important;
    }
     
    .homev2-thq-text-elm38,
    .homev2-thq-text-elm39 {
        white-space: normal !important;
    }
     
    .ec-rodape-contato {
        flex-direction: column !important;
        align-items: center !important;
        gap: 2px !important;
    }
}

@media (max-width: 768px) {

    .homev2-thq-rodape-linha2 {
        flex-direction: column !important;
        align-items: center !important;
        gap: 10px !important;
        text-align: center !important;
    }

    .homev2-thq-rectangle16-elm {
        width: 100% !important;
        justify-content: center !important;
        text-align: center !important;
    }

    .homev2-thq-text-elm35 {
        white-space: normal !important; /* ESSENCIAL */
        text-align: center !important;
        line-height: 1.4 !important;
    }

    .homev2-thq-rectangle17-elm {
        justify-content: center !important;
    }

    .homev2-thq-versoreduzida011-elm {
        margin-top: 0 !important; /* remove aquele -15px no mobile */
    }
}

/* ============================================================
   EuroCuida.css — versão corrigida
   ============================================================ */

:root {
    --ec-blue: #0055A2;
    --ec-blue-dark: #2C3A64;
    --ec-blue-alpha: rgba(44, 58, 100, 0.23);
    --ec-white: #FFFFFF;
    --ec-light-blue: #00AEDE;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

/* ===================== CONTAINER ===================== */
.homev2-container {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: 100vh;
    overflow-x: hidden;
}

/* ===================== MAPA FIX ===================== */

.ec-mapa {
    width: 100% !important;
    height: 300px !important;
    min-height: 300px !important;
    border-radius: 20px;
    overflow: hidden;
    display: block !important;
}

/* CORREÇÃO PRINCIPAL */
@media (min-width: 769px) {
    .ec-mapa {
        flex: 1 1 auto !important;
        width: 100% !important;
        height: clamp(220px, 25vw, 340px) !important;
    }
}

.ec-mapa .leaflet-container {
    width: 100% !important;
    height: 100% !important;
}

/* ===================== RODAPÉ ===================== */

.homev2-thq-rodapversobranca-elm {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 24px 0;
    position: relative;
}

.homev2-thq-rodape-linha1 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.homev2-thq-group5-elm {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.ec-rodape-contato {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

/* RESPONSIVO */
@media (max-width: 768px) {

    .homev2-thq-rodape-linha1 {
        flex-direction: column;
        text-align: center;
    }

    .homev2-thq-group5-elm {
        align-items: center;
    }

    .ec-rodape-contato {
        justify-content: center;
    }

    .homev2-thq-rodape-linha2 {
        flex-direction: column;
    }
}

/* ===================== INPUTS ===================== */

.ec-input {
    width: 100%;
    height: 52px;
    border-radius: 999px;
    border: none;
    background: rgba(255,255,255,0.92);
    color: #2C3A64;
    padding: 0 20px;
    font-size: 16px;
}

/* ===== FIX RODAPÉ ===== */

.homev2-thq-rodape-linha1 {
    justify-content: space-between !important;
    gap: clamp(12px, 2vw, 32px);
}

.homev2-thq-group5-elm {
    justify-content: center;
}

.ec-rodape-contato {
    flex-wrap: wrap;
    gap: clamp(8px, 1.5vw, 20px);
}

/* RESPONSIVO */
@media (max-width: 768px) {

    .homev2-thq-rodape-linha1 {
        flex-direction: column !important;
        align-items: center !important;
        text-align: center !important;
        gap: 10px !important;
    }

    .homev2-thq-group5-elm {
        align-items: center !important;
    }

    .ec-rodape-contato {
        justify-content: center;
    }

    .homev2-thq-rodape-linha2 {
        flex-direction: column !important;
    }

    .homev2-thq-rectangle17-elm {
        width: 100% !important;
        max-width: 220px;
    }
}

/* ===== FIX MOBILE RODAPÉ CONTATO ===== */
@media (max-width: 768px) {

    .ec-rodape-contato {
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 6px !important;
    }

     
    .homev2-thq-text-elm39 {
        text-align: center !important;
        white-space: normal !important;
    }
}

/* ===== MOBILE — AJUSTE RODAPÉ EUROCUIDA ===== */
@media (max-width: 768px) {

    /* ==============================
       EMAIL + TELEFONE (MESMA LINHA)
       ============================== */
    .ec-rodape-contato {
        display: flex !important;
        flex-direction: row !important; /* fica lado a lado */
        justify-content: center !important;
        align-items: center !important;
        gap: 12px !important;
        flex-wrap: wrap; /* evita quebrar layout em telas menores */
        width: 100%;
    }

    
    .homev2-thq-text-elm39 {
        text-align: center !important;
        white-space: nowrap !important;
        font-size: clamp(10px, 3.2vw, 14px) !important;
    }

    /* ==============================
       LINHA 2 (PÍLULA)
       ============================== */
    .homev2-thq-rodape-linha2 {
        flex-direction: column !important; /* quebra linha */
        align-items: center !important;
        gap: 10px !important;
    }

    /* pílula grande */
    .homev2-thq-rectangle16-elm {
        width: 100% !important;
        max-width: 320px !important;
        height: auto !important;
        padding: 10px 16px !important;
    }

    .homev2-thq-text-elm35 {
        font-size: clamp(10px, 3vw, 14px) !important; /* diminui fonte */
        text-align: center !important;
        white-space: normal !important;
    }

    /* pílula menor (logo) */
    .homev2-thq-rectangle17-elm {
        width: 100% !important;
        max-width: 180px !important;
    }
}

/* ===== RODAPÉ MOBILE — PIXEL PERFECT FIGMA ===== */
@media (max-width: 768px) {

    /* BLOCO SUPERIOR */
    .homev2-thq-rodape-linha1 {
        flex-direction: column !important;
        align-items: center !important;
        gap: 12px !important;
        text-align: center !important;
    }

    .homev2-thq-group39865-elm {
        width: 140px !important;
    }

    .homev2-thq-group5-elm {
        align-items: center !important;
        text-align: center !important;
    }

    .homev2-thq-text-elm37 {
        font-size: 16px !important;
        line-height: 1.3 !important;
    }

    /* EMAIL + TELEFONE */
    .ec-rodape-contato {
        display: flex !important;
        flex-direction: row !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 20px !important;
        margin-top: 6px !important;
    }

    .homev2-thq-text-elm38,
    .homev2-thq-text-elm39 {
        font-size: 15px !important;
        white-space: nowrap !important;
    }

    /* LINHA INFERIOR */
    .homev2-thq-rodape-linha2 {
        flex-direction: row !important; /* 👈 lado a lado como no Figma */
        justify-content: center !important;
        align-items: center !important;
        gap: 16px !important;
        margin-top: 16px !important;
    }

    /* PÍLULA GRANDE */
    .homev2-thq-rectangle16-elm {
        width: auto !important;
        max-width: 260px !important;
        padding: 10px 18px !important;
        border-radius: 999px !important;
    }

    .homev2-thq-text-elm35 {
        font-size: 12px !important;
        text-align: center !important;
        line-height: 1.3 !important;
    }

    /* PÍLULA DLOA */
    .homev2-thq-rectangle17-elm {
        width: auto !important;
        padding: 8px 14px !important;
        border-radius: 999px !important;
        gap: 6px !important;
    }

    .homev2-thq-text-elm36 {
        font-size: 11px !important;
    }

    .homev2-thq-versoreduzida011-elm {
        width: 44px !important;
    }
}

/* ===== MOBILE FINAL — AJUSTE PROFISSIONAL ===== */
@media (max-width: 768px) {

    /* BLOCO GERAL */
    .homev2-thq-rodapversobranca-elm {
        padding: 24px 16px !important;
    }

    /* LOGO */
    .homev2-thq-group39865-elm {
        width: 140px !important;
        margin-bottom: 8px;
    }

    /* TEXTO CAE */
    .homev2-thq-text-elm37 {
        font-size: 16px !important;
        line-height: 1.4 !important;
        text-align: center;
    }

    /* EMAIL + TEL */
    .ec-rodape-contato {
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 18px !important;
        margin-top: 8px !important;
    }

    .ec-contato-item {
        font-size: 13px;
        display: flex;
        align-items: center;
    }

    /* LINHA PÍLULAS */
    .homev2-thq-rodape-linha2 {
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 14px !important;
        margin-top: 20px !important;
    }

    /* PÍLULA GRANDE */
    .homev2-thq-rectangle16-elm {
        max-width: 260px !important;
        padding: 12px 18px !important;
    }

    .homev2-thq-text-elm35 {
        font-size: 12px !important;
        line-height: 1.4 !important;
    }

    /* PÍLULA DLOA */
    .homev2-thq-rectangle17-elm {
        padding: 8px 14px !important;
    }

    .homev2-thq-versoreduzida011-elm {
        width: 42px !important;
    }
}

/* ===== MOBILE FINAL — AJUSTE PROFISSIONAL ===== */
@media (max-width: 768px) {

    /* BLOCO GERAL */
    .homev2-thq-rodapversobranca-elm {
        padding: 24px 16px !important;
    }

    /* LOGO */
    .homev2-thq-group39865-elm {
        width: 140px !important;
        margin-bottom: 8px;
    }

    /* TEXTO CAE */
    .homev2-thq-text-elm37 {
        font-size: 16px !important;
        line-height: 1.4 !important;
        text-align: center;
    }

    /* EMAIL + TEL */
    .ec-rodape-contato {
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 18px !important;
        margin-top: 8px !important;
    }

    .ec-contato-item {
        font-size: 13px;
        display: flex;
        align-items: center;
    }

    /* LINHA PÍLULAS */
    .homev2-thq-rodape-linha2 {
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 14px !important;
        margin-top: 20px !important;
    }

    /* PÍLULA GRANDE */
    .homev2-thq-rectangle16-elm {
        max-width: 260px !important;
        padding: 12px 18px !important;
    }

    .homev2-thq-text-elm35 {
        font-size: 10px !important;
        line-height: 1.4 !important;
    }

    /* PÍLULA DLOA */
    .homev2-thq-rectangle17-elm {
        padding: 8px 14px !important;
    }

    .homev2-thq-versoreduzida011-elm {
        width: 42px !important;
    }
}

/* ================================
   FIX DEFINITIVO RODAPÉ MOBILE
   ================================ */
@media (max-width: 768px) {

    /* container geral */
    .homev2-thq-rodape-linha1 {
        flex-direction: column !important;
        align-items: center !important;
        gap: 12px !important;
        text-align: center !important;
    }

    /* bloco direito */
    .homev2-thq-group5-elm {
        align-items: center !important;
        text-align: center !important;
        margin-left: 0 !important;
    }

    /* 👉 CONTATO (AQUI ESTAVA O PROBLEMA) */
    .ec-rodape-contato {
        flex-direction: row !important; /* força linha */
        justify-content: center !important; /* centraliza */
        align-items: center !important;
        gap: 16px !important;
        width: auto !important;
    }

    /* textos */
    
    .homev2-thq-text-elm39 {
        white-space: nowrap !important;
        text-align: center !important;
        font-size: 13px !important;
        margin: 0 !important;
    }

    /* ================================
       PÍLULAS
       ================================ */

    .homev2-thq-rodape-linha2 {
        flex-direction: row !important; /* lado a lado */
        justify-content: center !important;
        align-items: center !important;
        gap: 12px !important;
        margin-top: 16px !important;
    }

    .homev2-thq-rectangle16-elm {
        flex: 0 1 auto !important;
        max-width: 260px !important;
        padding: 10px 16px !important;
    }

    .homev2-thq-text-elm35 {
        font-size: 12px !important;
        line-height: 1.3 !important;
        white-space: normal !important;
    }

    .homev2-thq-rectangle17-elm {
        flex: 0 0 auto !important;
        width: auto !important;
        padding: 8px 12px !important;
    }

    .homev2-thq-versoreduzida011-elm {
        width: 42px !important;
    }
}

/* ===== RODAPÉ MOBILE FINAL (IGUAL FIGMA) ===== */
@media (max-width: 768px) {

    /* FUNDO (garantia de contraste) */
    .homev2-thq-rodapversobranca-elm {
        padding: 28px 16px !important;
        text-align: center !important;
    }

    /* LOGO */
    .homev2-thq-group39865-elm {
        width: 150px !important;
        margin: 0 auto 10px auto !important;
    }

    /* BLOCO TEXTO */
    .homev2-thq-group5-elm {
        align-items: center !important;
        text-align: center !important;
    }

    .homev2-thq-text-elm37 {
        color: #ffffff !important;
        font-size: 18px !important;
        line-height: 1.35 !important;
        margin-bottom: 6px !important;
    }

    /* ===== CONTATO ===== */
    .ec-rodape-contato {
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 18px !important;
        margin-top: 6px !important;
    }

    .ec-contato-link {
        color: #ffffff !important;
        text-decoration: underline !important;
        font-size: 14px !important;
        white-space: nowrap;
    }

    .ec-contato-tel {
        color: #ffffff !important;
        font-size: 14px !important;
        white-space: nowrap;
    }

    /* ===== LINHA PÍLULAS ===== */
    .homev2-thq-rodape-linha2 {
        display: flex !important;
        flex-direction: row !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 14px !important;
        margin-top: 20px !important;
    }

    /* PÍLULA GRANDE */
    .homev2-thq-rectangle16-elm {
        background-color: #ffffff !important;
        max-width: 260px !important;
        padding: 12px 20px !important;
        border-radius: 999px !important;
    }

    .homev2-thq-text-elm35 {
        color: #0055A2 !important;
        font-size: 12px !important;
        text-align: center !important;
        line-height: 1.4 !important;
    }

    /* PÍLULA DLOA */
    .homev2-thq-rectangle17-elm {
        background-color: #ffffff !important;
        padding: 8px 14px !important;
        border-radius: 999px !important;
        display: flex !important;
        align-items: center !important;
        gap: 6px !important;
    }

    .homev2-thq-text-elm36 {
        color: #0055A2 !important;
        font-size: 11px !important;
    }

    .homev2-thq-versoreduzida011-elm {
        width: 44px !important;
    }
}

/* ================= FOOTER BASE ================= */
.ec-footer {
    width: 100%;
    color: #fff;
}

/* ================= DESKTOP ================= */
.ec-footer--desktop {
    display: block;
}

.ec-footer-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.ec-footer-logo {
    width: 180px;
}

.ec-footer-info {
    text-align: right;
}

.ec-footer-title {
    font-size: 18px;
    font-weight: 600;
}

.ec-footer-contact {
    margin-top: 6px;
    display: flex;
    gap: 12px;
    justify-content: flex-end;
}

    .ec-footer-contact a {
        color: #fff;
        text-decoration: underline;
    }

.ec-footer-bottom {
    margin-top: 20px;
    display: flex;
    justify-content: center;
    gap: 20px;
}

/* ================= MOBILE ================= */
.ec-footer--mobile {
    display: none;
}

/* ================= PILLS ================= */
.ec-pill {
    background: #fff;
    color: #0055A2;
    padding: 10px 18px;
    border-radius: 999px;
    font-size: 12px;
    text-align: center;
}

.ec-pill--logo {
    display: flex;
    align-items: center;
    gap: 6px;
}

    .ec-pill--logo img {
        width: 50px;
    }

/* ================= MOBILE LAYOUT ================= */
@media (max-width: 768px) {

    .ec-footer--desktop {
        display: none;
    }

    .ec-footer--mobile {
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        padding: 24px 16px;
        gap: 12px;
    }

    .ec-footer-logo-mobile {
        width: 140px;
    }

    .ec-footer-title-mobile {
        font-size: 18px;
        font-weight: 600;
        line-height: 1.3;
    }

    .ec-footer-contact-mobile {
        display: flex;
        gap: 16px;
        font-size: 14px;
    }

        .ec-footer-contact-mobile a {
            color: #fff;
            text-decoration: underline;
        }

    .ec-footer-pills-mobile {
        display: flex;
        gap: 12px;
        margin-top: 10px;
    }

    .ec-pill {
        font-size: 12px;
        padding: 10px 14px;
        max-width: 240px;
    }
}

@media (max-width: 768px) {

    /* Footer: ícones ao lado do email e telefone */
    #sec-contato .ec-rodape-contato {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-end !important; /* alinha o grupo à direita do bloco */
        gap: clamp(12px, 2vw, 28px) !important;
        width: auto !important;
    }

    .ec-contato-item {
        display: flex;
        align-items: center;
        gap: 8px;
        white-space: nowrap;
        flex-shrink: 0;
    }

    .ec-contato-icone {
        width: clamp(14px, 1.6vw, 18px);
        height: auto;
        flex-shrink: 0;
        display: inline-block;
        vertical-align: middle;
    }

    .ec-contato-link,
    .ec-contato-tel {
        color: inherit;
        text-decoration: underline;
        font-family: inherit;
        font-size: inherit;
        line-height: 1;
    }

    /* Mobile: mantém em linha mas com espaçamento menor e centralizado */
    @media (max-width: 768px) {
        #sec-contato .ec-rodape-contato {
            justify-content: center !important;
            gap: 12px !important;
            flex-wrap: wrap;
        }

        .ec-contato-item {
            gap: 6px;
        }

        .ec-contato-icone {
            width: 16px;
        }
    }
     