/* =========================================================
   Blocos Workmedia — wm-styles.css  v1.5.0
   workmedia.com.br
   ========================================================= */

/* =========================================================
   DESIGN TOKENS
   ========================================================= */
:root {
    --wm-navy:      #0a192f;
    --wm-ciano:     #00cfde;
    --wm-claro:     #f8fafc;
    --wm-borda:     #e2e8f0;

    --wm-sombra-sm: 0 2px 8px  rgba(0,0,0,.07);
    --wm-sombra-md: 0 8px 32px rgba(0,0,0,.09);
    --wm-sombra-lg: 0 20px 48px rgba(0,0,0,.16);
    --wm-sombra:    var(--wm-sombra-md);

    --wm-radius-sm: .6rem;
    --wm-radius-md: 1rem;
    --wm-radius-lg: 1.25rem;

    --wm-ease:      cubic-bezier(.4, 0, .2, 1);
    --wm-fast:      .22s;
    --wm-mid:       .35s;
    --wm-slow:      .5s;

    --wm-g1: #e8192c;
    --wm-g2: #c0102a;
    --wm-ic: #ffffff;
    --wm-fi: #00cfde;
    --wm-cb: #0a192f;
    --wm-cf: #ffffff;
}

/* =========================================================
   RESET LOCAL
   ========================================================= */
.wm-wrapper,
.wm-wrapper *,
.wm-grade-planos,
.wm-grade-planos * { box-sizing: border-box; }

/* =========================================================
   WRAPPER
   ========================================================= */
.wm-wrapper { position: relative; margin: 40px auto; width: 100%; }

/* =========================================================
   SWIPER — base
   ========================================================= */
.wm-carrossel.swiper {
    overflow:   visible;
    padding:    20px 0;
    visibility: hidden;   /* JS coloca visible após Swiper calcular posições */
}
/* Fallback: se JS falhar, mostra após 500ms via CSS animation */
.wm-carrossel.swiper {
    animation: wmf-show 0s 0.5s forwards;
}
@keyframes wmf-show { to { visibility: visible; } }
/* Padrão: overflow hidden no wrapper externo para não vazar */
.wm-estilo-padrao .wm-wrapper { overflow: hidden; }
.wm-carrossel.swiper .swiper-wrapper { display: flex; flex-wrap: nowrap; box-sizing: content-box; }
.wm-carrossel.swiper .swiper-slide   { flex-shrink: 0; height: auto; }

/* =========================================================
   ESTILO: PADRÃO
   ========================================================= */
.wm-setas-laterais {
    position: absolute; top: 20px; left: -18px; right: -18px; bottom: 0;
    display: flex; align-items: center; justify-content: space-between;
    pointer-events: none; z-index: 10;
}
.wm-setas-laterais .wm-seta { pointer-events: all; }

.wm-estilo-padrao .wm-corpo      { flex-direction: row; align-items: center; }
.wm-estilo-padrao .wm-beneficios { flex: 1; min-width: 0; }
.wm-estilo-padrao .wm-cta-wrap   { flex-shrink: 0; }

/* =========================================================
   ESTILO: METRO
   – centeredSlides:true, peek dos dois lados
   ========================================================= */
.wm-estilo-metro .wm-carrossel.swiper { overflow: visible !important; }

/* Scale do metro controlado pela flag "Zoom de destaque" (.wm-zoom-ativo)
   Mantido aqui apenas transform-origin para quando zoom estiver ativo */
.wm-estilo-metro .wm-card {
    transform-origin: center center;
}
.wm-estilo-metro .wm-beneficios { grid-template-columns: 1fr; }




/* =========================================================
   ESTILO: PADRÃO — wipe/curtain reveladora com clip-path
   A barra varre o card: cobre → slide troca por baixo → revela.
   ========================================================= */
.wm-curtain {
    position:      absolute;
    inset:         0;
    background:    linear-gradient(100deg, var(--wm-navy) 60%, #0d2a50);
    border-radius: inherit;
    z-index:       20;
    pointer-events:none;
    /* Estado inicial: barra fora à DIREITA (invisível) */
    clip-path:  inset(0 0 0 100%);
    transition: clip-path .38s cubic-bezier(.77, 0, .18, 1);
}

/* Fase 1 — barra varre da esquerda → cobre o card */
.wm-curtain.wm-curtain--cover {
    clip-path: inset(0 0 0 0);
}

/* Fase 2 — barra sai pela direita → revela novo card */
.wm-curtain.wm-curtain--reveal {
    clip-path: inset(0 0 0 100%);
    transition: clip-path .38s .02s cubic-bezier(.77, 0, .18, 1);
}

/* Direção invertida: barra começa fora à ESQUERDA */
.wm-curtain.wm-curtain--dir-inv {
    clip-path: inset(0 100% 0 0);
}
.wm-curtain.wm-curtain--dir-inv.wm-curtain--cover {
    clip-path: inset(0 0 0 0);
}
.wm-curtain.wm-curtain--dir-inv.wm-curtain--reveal {
    clip-path: inset(0 100% 0 0);
    transition: clip-path .38s .02s cubic-bezier(.77, 0, .18, 1);
}

/* Metro + inverter: dir:rtl + centeredSlides:true + initialSlide:0.
   Card 1 centralizado. Cards 2, 3... peeking à ESQUERDA (RTL layout).
   Clicar → move para esquerda, card 2 vem da esquerda ao centro.
/* Metro + inverter: scaleX(-1) espelha o carrossel horizontalmente.
   Sem dir:rtl — nao quebra icones Font Awesome.
   Carrossel espelhado: slides a DIREITA aparecem a ESQUERDA.
   Cada slide re-espelhado para LTR. Card 1 centralizado,
   cards 2,3 peeking a ESQUERDA. */
.wm-metro-inv .wm-carrossel.swiper {
    overflow:  visible !important;
    transform: scaleX(-1);
}
/* Un-mirror no .wm-card (não no .swiper-slide) — funciona tanto no
   frontend (Swiper inicializado) quanto no editor (sem Swiper) */
.wm-metro-inv .wm-card {
    transform: scaleX(-1);
}

/* =========================================================
   ZOOM DE DESTAQUE — flag global, todos os estilos
   Classe .wm-zoom-ativo aplicada no wrapper pelo JS.
   Quando flag OFF: zero efeito (sem transição, sem escala).
   ========================================================= */

/* Metro normal: zoom no slide ativo (.wm-slide-ativo setado pelo JS) */
.wm-zoom-ativo.wm-estilo-metro:not(.wm-metro-inv) .wm-card {
    transition:  transform var(--wm-slow) var(--wm-ease),
                 box-shadow var(--wm-slow) var(--wm-ease);
    will-change: transform;
}
.wm-zoom-ativo.wm-estilo-metro:not(.wm-metro-inv) .swiper-slide.wm-slide-ativo .wm-card {
    transform:  scale(1.06);
    box-shadow: var(--wm-sombra-lg);
    z-index:    2;
}

/* Metro invertido: zoom no slide ativo (.wm-slide-ativo setado pelo JS)
   O scaleX(-1) já está no .wm-card — adicionamos scale() por cima via transform */
.wm-zoom-ativo.wm-estilo-metro.wm-metro-inv .wm-card {
    transition:  transform var(--wm-slow) var(--wm-ease),
                 box-shadow var(--wm-slow) var(--wm-ease);
    will-change: transform;
}
.wm-zoom-ativo.wm-estilo-metro.wm-metro-inv .swiper-slide.wm-slide-ativo .wm-card {
    transform:  scaleX(-1) scale(1.06);
    box-shadow: var(--wm-sombra-lg);
    z-index:    2;
}

/* Padrão: zoom sutil no slide visível */
.wm-zoom-ativo.wm-estilo-padrao .swiper-slide-active .wm-card {
    transform:  scale(1.03);
    box-shadow: var(--wm-sombra-lg);
    transition: transform var(--wm-slow) var(--wm-ease),
                box-shadow var(--wm-slow) var(--wm-ease);
}

/* =========================================================
   CARD — estrutura
   ========================================================= */
.wm-card {
    background:     #fff;
    border-radius:  1.25rem;   /* fallback; sobrescrito via !important no painel */
    box-shadow:     var(--wm-sombra-md);
    border:         1px solid var(--wm-borda);
    overflow:       hidden;    /* essencial para o raio clipar o cabeçalho */
    display:        flex;
    flex-direction: column;
    height:         100%;
    /* transition para zoom suave */
    transition:     box-shadow var(--wm-slow) var(--wm-ease);
}

.wm-cabecalho {
    padding:    26px 30px;
    color:      #fff;
    background: linear-gradient(135deg, var(--wm-g1,#e8192c), var(--wm-g2,#c0102a));
    /* border-radius herdado do .wm-card via overflow:hidden — não setar aqui */
}

.wm-cab-topo { display: flex; align-items: center; gap: 16px; }

/* Ícone do card */
.wm-icone-box {
    width: 52px; height: 52px; min-width: 52px;
    background:      rgba(255,255,255,.20);
    border-radius:   var(--wm-radius-sm);
    display:         flex; align-items: center; justify-content: center;
    flex-shrink:     0; overflow: hidden; padding: 10px;
    font-size:       24px;
    color:           var(--wm-ic, #ffffff);
}
.wm-icone-box i,
.wm-icone-box i::before    { font-size: 1em; line-height: 1; color: inherit; display: block; }
.wm-icone-box > span,
.wm-icone-box span.e-font-icon-svg {
    display: flex; align-items: center; justify-content: center;
    width: 100%; height: 100%; font-size: inherit; color: inherit; line-height: 1;
}
.wm-icone-box svg,
.wm-icone-box > span svg,
.wm-icone-box span.e-font-icon-svg svg {
    display: block; width: 1em; height: 1em; max-width: 100%; max-height: 100%;
    fill: currentColor; color: inherit;
}

/* Textos cabeçalho */
.wm-etiqueta {
    display: inline-block;
    background: rgba(255,255,255,.22); border: 1px solid rgba(255,255,255,.35);
    padding: 2px 10px; border-radius: 99px;
    font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
    margin-bottom: 4px;
}
.wm-titulo    { margin: 4px 0 6px; font-size: 22px; font-weight: 800; color: #fff !important; }
.wm-descricao { margin: 0; opacity: .88; font-size: 13px; line-height: 1.5; color: #fff !important; }

/* Corpo do card */
.wm-corpo {
    padding: 24px 30px; flex-grow: 1;
    display: flex; flex-direction: column; justify-content: space-between; gap: 18px;
}

/* Benefícios */
.wm-beneficios {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}
.wm-beneficio { display: flex; align-items: center; gap: 7px; font-size: 14px; color: var(--wm-navy); }

/* Ícone de benefício */
.wm-b-icone {
    display: flex; align-items: center;
    font-size: 16px; flex-shrink: 0; line-height: 1;
    color: var(--wm-fi, #00cfde);
}
.wm-b-icone i,
.wm-b-icone i::before               { color: inherit !important; font-size: inherit; line-height: 1; }
.wm-b-icone span,
.wm-b-icone span.e-font-icon-svg    { display: flex; align-items: center; color: inherit; font-size: inherit; line-height: 1; }
.wm-b-icone svg                     { width: 1em; height: 1em; display: block; flex-shrink: 0; }
.wm-b-icone > svg                   { fill: none !important; stroke: currentColor !important; stroke-width: 2.5; }
.wm-b-icone span svg,
.wm-b-icone span.e-font-icon-svg svg { width: 1em !important; height: 1em !important; fill: currentColor !important; stroke: none !important; }
.wm-b-icone span svg *              { fill: currentColor !important; stroke: none !important; }

/* =========================================================
   BOTÃO CTA
   ========================================================= */
.wm-cta {
    display: inline-flex; align-items: center; gap: 9px;
    padding: 12px 26px; border-radius: var(--wm-radius-md);
    font-size: 14px; font-weight: 700;
    text-decoration: none !important; white-space: nowrap;
    cursor: pointer; border: none; line-height: 1.4;
    background-color: var(--wm-cb, #0a192f);
    color:            var(--wm-cf, #ffffff) !important;
    transition: transform var(--wm-fast) ease,
                box-shadow var(--wm-fast) ease,
                filter var(--wm-fast) ease;
}
.wm-cta:hover        { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,0,0,.14); filter: brightness(.92); text-decoration: none !important; }
.wm-cta i            { font-size: .9em; color: inherit; }
.wm-cta svg          { width: .9em; height: .9em; display: inline-block; stroke: currentColor; fill: none; flex-shrink: 0; vertical-align: middle; }
.wm-cta-navy         { background-color: var(--wm-navy);  color: #fff !important; }
.wm-cta-ciano        { background-color: var(--wm-ciano); color: #fff !important; }
.wm-cta-contorno     { background-color: transparent; border: 1.5px solid var(--wm-borda); color: var(--wm-navy) !important; }

/* =========================================================
   NAVEGAÇÃO
   ========================================================= */
.wm-nav-bar {
    display: flex; align-items: center; gap: 10px;
    margin-top: 26px; padding: 0 20px; flex-wrap: wrap; width: 100%;
}
.wm-setas { display: flex; gap: 8px; flex-shrink: 0; }

.wm-seta {
    width: 38px; height: 38px;
    background: #fff; border-radius: 50%;
    border: 1.5px solid var(--wm-borda);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; color: var(--wm-navy);
    box-shadow: var(--wm-sombra-sm);
    transition: background var(--wm-fast), color var(--wm-fast), border-color var(--wm-fast), box-shadow var(--wm-fast);
    flex-shrink: 0; user-select: none;
}
.wm-seta:hover        { background: var(--wm-navy); color: #fff; border-color: var(--wm-navy); box-shadow: 0 4px 14px rgba(10,25,47,.22); }
.wm-seta svg          { width: 16px; height: 16px; display: block; stroke: currentColor; fill: none; flex-shrink: 0; }

.wm-dots { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }

.wm-dot {
    -webkit-appearance: none; appearance: none; margin: 0;
    display: inline-flex; align-items: center; gap: 6px;
    padding: .6em 1.25em; border-radius: 99px;
    font-size: 12px; font-weight: 600; line-height: 1.4;
    white-space: nowrap; box-sizing: border-box;
    background-color: #fff; color: var(--wm-navy);
    border: 1.5px solid var(--wm-borda); box-shadow: var(--wm-sombra-sm);
    cursor: pointer;
    transition: background-color var(--wm-fast), color var(--wm-fast),
                border-color var(--wm-fast), box-shadow var(--wm-fast);
}
.wm-dot.ativo             { background-color: var(--wm-navy); color: #fff; border-color: var(--wm-navy); box-shadow: 0 4px 14px rgba(10,25,47,.22); }
.wm-dot:hover:not(.ativo) { background-color: var(--wm-claro); border-color: var(--wm-navy); }
.wm-dot-ic                { display: inline-flex; align-items: center; font-size: 1em; line-height: 1; flex-shrink: 0; }
.wm-dot-ic i              { font-size: 1em; color: inherit; }
.wm-dot-ic svg            { width: 1em; height: 1em; fill: currentColor; }

/* =========================================================
   SUPER TEXTO
   ========================================================= */
.wm-super-texto { font-size: 52px; font-weight: 800; color: #fff; line-height: 1.15; margin-bottom: 24px; }

/* =========================================================
   PLANOS
   ========================================================= */
.wm-grade-planos { display: flex; flex-wrap: wrap; gap: 28px; }

.wm-plano {
    background: #fff; padding: 36px; border-radius: var(--wm-radius-lg);
    border: 1.5px solid var(--wm-borda); position: relative;
    flex: 1 1 260px; min-width: 260px;
    box-shadow: var(--wm-sombra-md);
    transition: box-shadow var(--wm-mid);
}
.wm-plano:hover              { box-shadow: var(--wm-sombra-lg); }
.wm-plano.destaque           { border-color: var(--wm-ciano); box-shadow: 0 20px 40px rgba(0,207,222,.12); }
.wm-plano-badge     { position: absolute; top: 0; left: 50%; transform: translate(-50%,-50%); background: var(--wm-ciano); color: #fff; padding: 5px 16px; border-radius: 99px; font-size: 10px; font-weight: 700; white-space: nowrap; }
.wm-plano-etiqueta  { color: var(--wm-ciano); font-size: 11px; font-weight: 700; text-transform: uppercase; display: block; }
.wm-plano-preco     { margin: 14px 0 22px; display: flex; align-items: baseline; gap: 4px; }
.wm-preco-valor     { font-size: 30px; font-weight: 800; color: var(--wm-navy); }
.wm-preco-periodo   { font-size: 13px; opacity: .6; }
.wm-plano-beneficios{ margin-bottom: 28px; }
.wm-plano-item      { display: flex; align-items: center; gap: 8px; font-size: 14px; margin-bottom: 8px; }
.wm-plano-item i    { color: var(--wm-ciano); }

/* =========================================================
   RESPONSIVIDADE
   ========================================================= */
@media (min-width: 768px) and (max-width: 1024px) {
    .wm-cabecalho      { padding: 22px 26px; }
    .wm-corpo          { padding: 22px 26px; }
    .wm-titulo         { font-size: 20px; }
    .wm-plano          { flex: 1 1 calc(50% - 14px); }
    .wm-setas-laterais { left: -10px; right: -10px; }
}
@media (max-width: 767px) {
    .wm-cabecalho                        { padding: 20px; }
    .wm-corpo                            { padding: 20px; }
    .wm-titulo                           { font-size: 18px; }
    .wm-descricao                        { font-size: 12px; }
    .wm-setas-laterais                   { left: -10px; right: -10px; }
    .wm-beneficios                       { grid-template-columns: 1fr; }
    .wm-cta                              { width: 100%; justify-content: center; }
    .wm-plano                            { flex: 1 1 100%; }
    .wm-dot                              { padding: .5em 1em; }
    .wm-estilo-padrao .wm-corpo          { flex-direction: column; align-items: flex-start; }
    .wm-estilo-padrao .wm-beneficios     { width: 100%; }
}



/* =================================================================
   CARROSSEL FLEX — widget fullscreen/hero  v3
   ================================================================= */

.wmf-wrapper {
    position: relative;
    width:     100%;
    overflow:  hidden;
    margin:    0;
    padding:   0;
}

/* Swiper ocupa 100% — overflow hidden garante que 1 card = tela inteira */
.wmf-carrossel.swiper {
    width:    100%;
    overflow: hidden;
    margin:   0;
    padding:  0;
}

/* swiper-wrapper é o flex row nativo do Swiper — não sobreescrever */

/* Slide — ocupa a largura do slot definido pelo slidesPerView */
.wmf-slide {
    position:      relative;
    width:         100%;   /* ocupa o slot — Swiper controla a largura real */
    min-height:    100vh;  /* sobrescrito pelo seletor Elementor */
    display:       flex;
    align-items:   center;
    overflow:      hidden;
    border:        none !important;
    border-radius: 0 !important;
    box-shadow:    none !important;
    padding:       0;
}

/* Máscara */
.wmf-mascara {
    position:       absolute;
    inset:          0;
    z-index:        1;
    pointer-events: none;
}

/* Vídeo de fundo */
.wmf-video-bg {
    position:   absolute;
    inset:      0;
    width:      100%;
    height:     100%;
    object-fit: cover;
    z-index:    0;
}

/* Conteúdo de texto — ocupa o espaço disponível */
.wmf-conteudo {
    position:        relative;
    z-index:         2;
    flex:            1;
    min-width:       0;
    padding:         20px;
    display:         flex;
    flex-direction:  column;
    justify-content: center;
}

/* ----------------------------------------------------------------
   IMAGEM LATERAL — liberdade total de posição e tamanho.
   position:absolute dentro do .wmf-slide (overflow:hidden).
   Os controles X/Y/largura/altura no painel controlam via inline style.
   ---------------------------------------------------------------- */
.wmf-imagem-lateral {
    position:   absolute;
    z-index:    3;          /* acima do conteúdo se necessário */
    top:        0;
    right:      0;          /* padrão: canto superior direito */
    width:      40%;        /* sobrescrito pelo slider de largura */
    height:     100%;
    display:    flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;   /* não bloqueia cliques no conteúdo */
}

.wmf-imagem-lateral img {
    /* width/height/object-fit/transform via inline style gerado pelo PHP */
    display:    block;
    max-width:  none;       /* sem limite — o usuário controla */
    max-height: none;       /* sem limite — o usuário controla */
}

/* Slide com imagem à DIREITA — conteúdo não deve sobrepor a imagem */
.wmf-img-direita  .wmf-conteudo  { padding-right: 44%; }   /* espaço para img */
.wmf-img-esquerda .wmf-imagem-lateral { right: auto; left: 0; }
.wmf-img-esquerda .wmf-conteudo  { padding-left: 44%; padding-right: 20px; }

/* Alinhamentos */
.wmf-layout-esquerda              { justify-content: flex-start; }
.wmf-layout-centro                { justify-content: center; }
.wmf-layout-centro .wmf-conteudo  { text-align: center; align-items: center; }
.wmf-layout-direita               { justify-content: flex-end; }
.wmf-layout-direita .wmf-conteudo { text-align: right; align-items: flex-end; }

/* Textos */
.wmf-subtitulo {
    font-size:      18px;
    font-weight:    600;
    opacity:        .8;
    margin:         0 0 10px;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.wmf-titulo {
    font-size:   52px;
    font-weight: 800;
    line-height: 1.1;
    margin:      0 0 16px;
}
.wmf-descricao {
    font-size:   16px;
    line-height: 1.6;
    opacity:     .88;
    margin:      0 0 22px;
}

/* Benefícios */
.wmf-beneficios {
    list-style: none;
    margin:     0 0 22px;
    padding:    0;
    display:    flex;
    flex-wrap:  wrap;
    gap:        8px 20px;
}
.wmf-beneficio { display: flex; align-items: center; gap: 8px; font-size: 15px; }
.wmf-b-icone   { display: flex; align-items: center; font-size: 18px; flex-shrink: 0; line-height: 1; }
.wmf-b-icone i, .wmf-b-icone i::before              { color: inherit !important; font-size: inherit; }
.wmf-b-icone span, .wmf-b-icone span.e-font-icon-svg { display: flex; align-items: center; color: inherit; font-size: inherit; line-height: 1; }
.wmf-b-icone > svg                                   { fill: none !important; stroke: currentColor !important; stroke-width: 2.5; width: 1em; height: 1em; display: block; }
.wmf-b-icone span svg                                { fill: currentColor !important; stroke: none !important; width: 1em !important; height: 1em !important; }
.wmf-b-icone span svg *                              { fill: currentColor !important; stroke: none !important; }

/* CTAs */
.wmf-ctas { display: flex; flex-wrap: wrap; gap: 12px; }
.wmf-cta {
    display:         inline-flex;
    align-items:     center;
    gap:             8px;
    padding:         13px 28px;
    font-size:       16px;
    font-weight:     700;
    text-decoration: none !important;
    border:          2px solid transparent;
    border-radius:   6px;
    cursor:          pointer;
    transition:      transform .2s, box-shadow .2s, filter .2s;
    white-space:     nowrap;
}
.wmf-cta:hover        { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.2); filter: brightness(.92); }
.wmf-cta svg          { width: .9em; height: .9em; stroke: currentColor; fill: none; display: inline-block; flex-shrink: 0; }
.wmf-cta-secundario   { border: 2px solid currentColor !important; }

/* ---- Setas ---- */
.wmf-seta {
    position:        absolute;
    top:             50%;
    transform:       translateY(-50%);
    z-index:         10;
    width:           56px;
    height:          56px;
    border-radius:   50%;
    border:          none;
    display:         flex;
    align-items:     center;
    justify-content: center;
    cursor:          pointer;
    background:      rgba(0,0,0,.35);
    color:           #fff;
    transition:      background .2s, transform .2s;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.wmf-seta:hover { background: rgba(0,0,0,.6); transform: translateY(-50%) scale(1.08); }
.wmf-prev       { left: 20px; }
.wmf-next       { right: 20px; }
.wmf-seta svg   { width: 22px; height: 22px; display: block; stroke: currentColor; fill: none; flex-shrink: 0; }

/* ---- Dots ---- */
.wmf-dots { position: absolute; z-index: 10; display: flex; gap: 8px; }
.wmf-dots-baixo-centro   { bottom: 28px; left: 50%; transform: translateX(-50%); flex-direction: row; }
.wmf-dots-baixo-esquerda { bottom: 28px; left: 28px; flex-direction: row; }
.wmf-dots-baixo-direita  { bottom: 28px; right: 28px; flex-direction: row; }
.wmf-dots-direita-meio   { right: 24px; top: 50%; transform: translateY(-50%); flex-direction: column; }
.wmf-dots-esquerda-meio  { left: 24px; top: 50%; transform: translateY(-50%); flex-direction: column; }

.wmf-dot-btn {
    width: 10px; height: 10px;
    border-radius: 50%; border: none; padding: 0; cursor: pointer;
    background: rgba(255,255,255,.5);
    transition: background .25s, transform .25s;
}
.wmf-dot-btn.ativo { background: #fff; transform: scale(1.4); }
.wmf-dot-btn:hover { background: rgba(255,255,255,.8); }

/* ---- Responsivo ---- */
@media (max-width: 1024px) {
    .wmf-titulo             { font-size: 36px; }
    .wmf-subtitulo          { font-size: 14px; }
    .wmf-descricao          { font-size: 14px; }
    .wmf-img-direita  .wmf-conteudo { padding-right: 20px; }
    .wmf-img-esquerda .wmf-conteudo { padding-left:  20px; }
    .wmf-imagem-lateral     { width: 35%; }
}

@media (max-width: 767px) {
    .wmf-titulo             { font-size: 26px; }
    .wmf-subtitulo          { font-size: 12px; }
    .wmf-descricao          { font-size: 13px; }
    .wmf-prev               { left: 8px; }
    .wmf-next               { right: 8px; }
    .wmf-seta               { width: 36px; height: 36px; }
    .wmf-seta svg           { width: 14px; height: 14px; }
    .wmf-imagem-lateral     { display: none; }  /* oculta em mobile */
    .wmf-img-direita  .wmf-conteudo { padding-right: 20px; }
    .wmf-img-esquerda .wmf-conteudo { padding-left:  20px; }
}
