/* =========================================================
   EV Header — Hotmart-style (standalone)
   Arquivo: core-header.css
   ========================================================= */

/* Carregar a família Nunito Sans */
@import url('https://fonts.googleapis.com/css2?family=Nunito+Sans:wght@400;600;700&display=swap');

/* -----------------------------
   Design Tokens (default: dark)
   ----------------------------- */
:root {
    /* layout tokens */
    --z-header: 30;
    --space-8: 16px;
    --border-width: 1px;
    --radius-2: 12px;
    --radius-round: 999px;

    /* THEME DEFAULT (dark) */
    --bg: #0b0f14;
    --fg: #ffffff;
    --fg-subtle: #e5e7eb;
    --surface: #0c1116;
    --border-color: rgba(255, 255, 255, .12);
    --bg-header-grad: linear-gradient(180deg, rgba(0, 0, 0, .72) 0%, rgba(0, 0, 0, .36) 38%, rgba(0, 0, 0, 0) 100%);

    --icon-bg: rgba(255, 255, 255, .06);
    --icon-hover-bg: rgba(255, 255, 255, .10);
    --icon-fg: #fff;
    --icon-bd: rgba(255, 255, 255, .12);

    --input-bg: rgba(255, 255, 255, .06);
    --input-bd: rgba(255, 255, 255, .22);
    --focus-ring: rgba(255, 255, 255, .32);

    --btn-contrast-bg: #fff;
    --btn-contrast-fg: #0f172a;
    --btn-contrast-bd: rgba(255, 255, 255, .9);

    --btn-ghost-fg: #fff;
    --btn-ghost-bd: rgba(255, 255, 255, .6);
    --btn-ghost-hover-bg: rgba(255, 255, 255, .12);

    --danger-bg: #f1416c;
    --danger-bd: #f1416c;

    --drawer-bg: var(--surface);
    --drawer-bd: rgba(255, 255, 255, .08);
    --menu-bg: var(--surface);
    --menu-bd: rgba(255, 255, 255, .12);
    --menu-link-fg: var(--fg-subtle);
    --modal-bg: var(--surface);
    --modal-bd: rgba(255, 255, 255, .12);
    --drawer-link-fg: #e5e7eb;
    --drawer-link-hover-bg: rgba(255, 255, 255, .07);
    --drawer-link-active-bg: rgba(255, 255, 255, .10);
    --drawer-section-fg: #9ca3af;
    --menu-link-hover-bg: rgba(255, 255, 255, .06);

    /* accent */
    --accent: #3b82f6;
}

/* LIGHT THEME */
[data-theme="light"] {
    color-scheme: light;
    --bg: #f8fafc;
    --fg: #0b1220;
    --fg-subtle: #334155;
    --surface: #ffffff;
    --border-color: rgba(17, 24, 39, .12);
    --bg-header-grad: linear-gradient(180deg, rgba(255, 255, 255, .85) 0%, rgba(255, 255, 255, .6) 30%, rgba(255, 255, 255, 0) 100%);

    --icon-bg: rgba(17, 24, 39, .06);
    --icon-hover-bg: rgba(17, 24, 39, .10);
    --icon-fg: #0f172a;
    --icon-bd: rgba(17, 24, 39, .15);

    --input-bg: rgba(17, 24, 39, .03);
    --input-bd: rgba(17, 24, 39, .18);
    --focus-ring: rgba(37, 99, 235, .35);

    --btn-contrast-bg: #0f172a;
    --btn-contrast-fg: #ffffff;
    --btn-contrast-bd: #0f172a;

    --btn-ghost-fg: #0f172a;
    --btn-ghost-bd: rgba(17, 24, 39, .35);
    --btn-ghost-hover-bg: rgba(17, 24, 39, .08);

    --danger-bg: #e11d48;
    --danger-bd: #e11d48;

    --drawer-bg: #ffffff;
    --drawer-bd: rgba(17, 24, 39, .12);
    --menu-bg: #ffffff;
    --menu-bd: rgba(17, 24, 39, .12);
    --menu-link-fg: #334155;
    --modal-bg: #ffffff;
    --modal-bd: rgba(17, 24, 39, .12);
    --drawer-link-fg: #0b1220;
    --drawer-link-hover-bg: rgba(17, 24, 39, .06);
    --drawer-link-active-bg: rgba(17, 24, 39, .10);
    --drawer-section-fg: #64748b;
    --menu-link-hover-bg: rgba(17, 24, 39, .06);

    --accent: #2563eb;
}

/* DARK (explícito) */
[data-theme="dark"] {
    color-scheme: dark;
}

/* -----------------------------
   Base / Acessibilidade
   ----------------------------- */
* {
    box-sizing: border-box
}

html, body {
    margin: 0;
    height: 100%;
    font-family: "Nunito Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
}

button, input, select, textarea {
    font: inherit;
}

body {
    background: var(--bg);
    color: var(--fg);
}

:focus {
    outline: none
}

:focus-visible {
    outline: 3px solid var(--focus-ring);
    outline-offset: 2px;
}

.focus-ring {
    -webkit-appearance: none
}

.visually-hidden {
    position: absolute !important;
    clip: rect(1px, 1px, 1px, 1px);
    padding: 0;
    border: 0;
    height: 1px;
    width: 1px;
    overflow: hidden;
    white-space: nowrap;
}

.skip-link {
    position: absolute;
    left: -999px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.skip-link:focus {
    left: var(--space-8);
    top: var(--space-8);
    width: auto;
    height: auto;
    background: var(--btn-contrast-bg);
    color: var(--btn-contrast-fg);
    padding: 8px 12px;
    border-radius: 10px;
    z-index: calc(var(--z-header) + 5);
}

/* Redução de movimento */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .001ms !important;
        scroll-behavior: auto !important;
    }
}

/* -----------------------------
   Header
   ----------------------------- */
.ev-header {
    position: sticky;
    top: 0;
    z-index: var(--z-header);
    background: var(--bg-header-grad);
    border-bottom: 0;
    backdrop-filter: saturate(160%) blur(6px);
}

@media (max-width: 560px) {
    .ev-header {
        backdrop-filter: saturate(140%) blur(4px)
    }
}

.ev-header__bar {
    display: flex;
    align-items: center;
    gap: 12px;
    height: 64px;
    max-width: 1280px;
    margin: 0 auto;
}

.ev-header__brand img {
    display: block;
    height: 36px
}

.header-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 12px;
    border: var(--border-width) solid var(--icon-bd);
    background: var(--icon-bg);
    color: var(--icon-fg);
    line-height: 0;
    box-shadow: 0 1px 0 rgba(255, 255, 255, .05) inset;
    transition: transform .18s cubic-bezier(.2, .8, .2, 1), box-shadow .18s ease, background .18s ease, border-color .18s ease;
}

.header-icon:hover {
    background: var(--icon-hover-bg);
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, .25);
}

.header-icon:active {
    transform: translateY(1px)
}

.header-icon:focus-visible {
    box-shadow: 0 0 0 2px var(--focus-ring) inset
}

.header-spacer {
    flex: 1
}

.ev-header__actions {
    display: flex;
    align-items: center;
    gap: 10px
}

.ev-header__actions .btn {
    min-height: 36px;
    padding: 0 12px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: transform .18s cubic-bezier(.2, .8, .2, 1), box-shadow .18s ease, filter .18s ease, background .18s ease, border-color .18s ease;
}

.btn-contrast {
    background: var(--btn-contrast-bg);
    color: var(--btn-contrast-fg);
    border: 1px solid var(--btn-contrast-bd);
}

.btn-contrast:hover {
    filter: brightness(0.98);
    box-shadow: 0 6px 18px rgba(255, 255, 255, .22);
}

.btn-ghost {
    background: transparent;
    color: var(--btn-ghost-fg);
    border: 1px solid var(--btn-ghost-bd);
}

.btn-ghost:hover {
    background: var(--btn-ghost-hover-bg);
    border-color: var(--btn-ghost-bd);
    box-shadow: inset 0 0 0 9999px rgba(0, 0, 0, 0);
}

.btn-danger {
    background: var(--danger-bg);
    border: 1px solid var(--danger-bd);
    color: #fff !important;
}

.btn-danger:hover {
    background: var(--danger-bg) !important;
    border: 1px solid var(--danger-bd) !important;
    color: #fff !important;
    box-shadow: 0 6px 18px rgba(241, 65, 108, .35);
}

.btn:focus-visible {
    filter: brightness(1.02);
    box-shadow: 0 0 0 2px var(--focus-ring) inset;
}

.input {
    appearance: none;
    background: var(--input-bg);
    color: var(--fg);
    border: 1px solid var(--input-bd);
    border-radius: 10px;
    min-height: 36px;
    padding: 0 10px;
}

.input:focus {
    outline: 3px solid var(--focus-ring);
    outline-offset: 2px;
}

/* seta do select (branca no escuro, preta no claro) */
select.input {
    /*background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' fill='white' viewBox='0 0 24 24'><path d='M7 10l5 5 5-5'/></svg>");*/
    background-repeat: no-repeat;
    background-position: right 10px center;
    padding-right: 30px;
}

[data-theme="light"] select.input {
    /*background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' fill='black' viewBox='0 0 24 24'><path d='M7 10l5 5 5-5'/></svg>");*/
}

/* -----------------------------
   Drawer (menu lateral) + backdrop
   ----------------------------- */
.drawer {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: 280px;
    max-width: 85vw;
    padding: 12px;
    background: var(--drawer-bg);
    border-right: 1px solid var(--drawer-bd);
    transform: translateX(-100%);
    transition: transform .25s cubic-bezier(.2, .8, .2, 1);
    z-index: calc(var(--z-header) + 1);
}

.drawer.is-open {
    transform: translateX(0)
}

.drawer__nav {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 8px;
}

.drawer__item {
    display: flex;
    gap: 10px;
    align-items: center;
    padding: 10px 12px;
    border-radius: 10px;
    color: var(--drawer-link-fg);
    text-decoration: none;
    border: 1px solid transparent;
}

.drawer__item:hover {
    background: var(--drawer-link-hover-bg);
    border-color: var(--drawer-bd);
}

.drawer__item.is-active {
    background: var(--drawer-link-active-bg);
    border-color: var(--drawer-bd);
}

.drawer__item:focus-visible {
    background: var(--drawer-link-hover-bg);
    border-color: var(--drawer-bd);
}

.drawer__section {
    margin: 12px 8px 4px;
    color: var(--drawer-section-fg);
    font-size: 12px;
    text-transform: uppercase;
}

.backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .4);
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease;
    z-index: var(--z-header);
}

.backdrop.is-visible {
    opacity: 1;
    pointer-events: auto;
}

/* -----------------------------
   Profile menu (popover)
   ----------------------------- */
.menu {
    position: absolute;
    right: 0;
    top: 100%;
    margin-top: 8px;
    min-width: 320px;
    background: var(--menu-bg);
    border: 1px solid var(--menu-bd);
    border-radius: 12px;
    padding: 12px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, .45);
    opacity: 0;
    transform: translateY(6px);
    pointer-events: none;
    transition: opacity .15s ease, transform .15s ease;
}

.menu--right {
    right: 0
}

.menu--right a {
    margin: 5px 0;
}

.menu[aria-hidden="false"] {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.menu a {
    display: block;
    padding: 10px;
    border-radius: 8px;
    color: var(--menu-link-fg);
    text-decoration: none;
}

.menu a:hover {
    background: var(--menu-link-hover-bg)
}

.menu a:focus-visible {
    background: var(--menu-link-hover-bg)
}

.menu hr {
    border: 0;
    border-top: 1px solid rgba(255, 255, 255, .08);
    margin: 6px 0;
}

.menu-panel {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 8px;
}

.menu__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.menu__label {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.menu__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 8px;
    background: var(--icon-bg);
    border: 1px solid var(--icon-bd);
}

.menu__text {
    display: flex;
    flex-direction: column;
    min-width: 0
}

.menu__title {
    font-weight: 600;
    color: var(--fg)
}

.menu__sub {
    font-size: 12px;
    color: var(--drawer-section-fg)
}

.menu__control {
    display: flex;
    align-items: center
}

/* Switch (tema) */
.switch {
    position: relative;
    display: inline-block;
    width: 44px;
    height: 24px
}

.switch input {
    opacity: 0;
    width: 0;
    height: 0
}

.slider {
    position: absolute;
    inset: 0;
    background: var(--input-bg);
    border: 1px solid var(--input-bd);
    border-radius: 999px;
    transition: background .18s ease, border-color .18s ease;
}

.slider:before {
    content: "";
    position: absolute;
    width: 18px;
    height: 18px;
    left: 3px;
    top: 50%;
    transform: translateY(-50%);
    background: var(--fg);
    border-radius: 50%;
    transition: transform .18s cubic-bezier(.2, .8, .2, 1);
}

.switch input:checked + .slider {
    background: var(--accent);
    border-color: var(--accent)
}

.switch input:checked + .slider:before {
    transform: translate(20px, -50%)
}

/* -----------------------------
   Modal
   ----------------------------- */
.modal {
    position: fixed;
    inset: 0;
    display: grid;
    place-items: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease;
    z-index: calc(var(--z-header) + 2);
}

.modal.is-open {
    opacity: 1;
    pointer-events: auto
}

.modal__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, .5)
}

.modal__dialog {
    position: relative;
    background: var(--modal-bg);
    border: 1px solid var(--modal-bd);
    border-radius: 16px;
    width: min(480px, 92vw);
    padding: 20px;
    box-shadow: 0 30px 80px rgba(0, 0, 0, .6);
    transform: scale(.98);
    transition: transform .2s ease;
}

.modal.is-open .modal__dialog {
    transform: scale(1)
}

.modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

.modal__body {
    color: #cbd5e1
}

.modal__footer {
    margin-top: 16px;
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

/* -----------------------------
   Responsivo
   ----------------------------- */
@media (max-width: 992px) {
    .ev-header__bar {
        height: 56px;
        padding: 0 var(--space-8);
    }

    .ev-header__brand img {
        height: 30px
    }

    .ev-header__actions .btn {
        min-height: 32px;
        padding: 0 10px;
        font-size: 14px
    }

    .header-icon {
        width: 36px;
        height: 36px;
        border-radius: 10px
    }
}

@media (max-width: 560px) {
    .ev-header__actions {
        gap: 8px
    }

    .btn-hide-label-sm {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        /*max-width: 112px;*/
    }

    .hide-sm {
        display: none !important
    }
}

/* =========================================
   Container — alinhado ao header
   ========================================= */

/* Tokens opcionais (caso queira ajustar globalmente) */
:root {
    --container-max: 1280px; /* mesmo do .ev-header__bar */
    /*--container-pad: 8px;     !* mesmo var(--space-8) *!*/
}

/* Container padrão — alinha com o header */
.ev-container {
    width: 100%;
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: calc(var(--container-pad) + env(safe-area-inset-left, 0px));
    padding-inline: calc(var(--container-pad) + env(safe-area-inset-right, 0px));
    padding-left: calc(var(--container-pad) + env(safe-area-inset-left, 0px));
    padding-right: calc(var(--container-pad) + env(safe-area-inset-right, 0px));
}

/* Evita “duplo padding” quando um container é aninhado (edge cases) */
.ev-container .ev-container {
    padding-left: 0;
    padding-right: 0;
}

/* Secções com espaçamento vertical previsível */
.ev-section {
    padding-block: clamp(28px, 6vw, 56px);
}

.ev-section--tight {
    padding-block: clamp(20px, 4vw, 36px);
}

.ev-section--loose {
    padding-block: clamp(40px, 8vw, 88px);
}

/* Variações de largura */
.ev-container--narrow {
    max-width: 960px;
}

.ev-container--wide {
    max-width: 1440px;
}

.ev-container--fluid {
    max-width: none;
}

/* ocupa toda a largura */

/* Variações de padding (gutter) */
.ev-container--edge {
    padding-left: 0;
    padding-right: 0;
}

.ev-container--gutter-sm {
    --container-pad: 12px;
}

.ev-container--gutter-lg {
    --container-pad: 24px;
}

/* Seções com “bleed” (full-bleed do fundo, conteúdo alinhado) */
.ev-bleed {
    width: 100%;
    margin-inline: calc(50% - 50vw);
    background: var(--surface);
    border-top: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
}

.ev-bleed > .ev-container {
    padding-block: clamp(28px, 6vw, 56px);
}

/* Responsivo — mantém o mesmo gutter do header em telas menores */
@media (max-width: 560px) {
    .ev-container {
        --container-pad: 12px;
    }
}

/* =============================
   Drawer — rodapé de preferências
   (adicionar ao final do arquivo)
   ============================= */
.drawer__footer {
    margin-top: auto;
    padding: 8px 4px;
}

.drawer__sep {
    border: 0;
    border-top: 1px solid var(--drawer-bd);
    margin: 8px 4px 12px;
}

/* Reuso (caso o bloco não exista no seu core, mantenha) */
.menu__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.menu__label {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.menu__text {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.menu__title {
    font-weight: 600;
    color: var(--fg);
}

.menu__sub {
    font-size: 12px;
    color: var(--drawer-section-fg);
}

.menu__control {
    display: flex;
    align-items: center;
}

/* =============================
   Idioma — versão empilhada
   (label em cima, select ocupa 100%)
   ============================= */
.drawer__footer .menu__row--stack {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    padding: 8px 2px;
    margin-top: 10px;
}

.drawer__footer .menu__row--stack .menu__label {
    align-items: center;
    gap: 10px;
}

.drawer__footer .menu__row--stack .menu__text {
    line-height: 1.15;
}

.drawer__footer .menu__row--stack .menu__sub {
    margin-top: 2px;
    /* Tom mais suave para o subtítulo */
    color: color-mix(in oklab, var(--fg) 60%, transparent);
}

.drawer__footer .menu__row--stack .menu__control {
    width: 100%;
}

.drawer__footer .menu__row--stack .menu__control .input {
    width: 100%;
    min-height: 40px; /* melhor área de toque */
    padding: 0 12px;
}

/* Breadcrumb */
.breadcrumbs {
    margin: 14px 1%;
    color: var(--fg-subtle);
    font-size: 14px
}

.breadcrumbs a {
    text-decoration: none;
    color: var(--fg-subtle);
}

/* =========================================================
   EV Footer — alinhado ao header / ev-container
   ========================================================= */

#ev-footer {
    margin-top: 40px;
    background: var(--surface);
    color: var(--fg-subtle);
    border-top: 1px solid var(--border-color);
}

/* Wrapper interno em grid, largura vem da .ev-container */
#ev-footer .ev-footer-inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
    margin-bottom: 16px;
}

/* Coluna da marca */
#ev-footer .ev-footer-brand {
    max-width: 340px;
}

#ev-footer .ev-footer-logo img {
    max-height: 34px;
    width: auto;
    display: block;
    margin-bottom: 12px;
}

/* Texto */
#ev-footer .ev-footer-text {
    font-size: 0.875rem;
    line-height: 1.5;
    color: var(--fg-subtle);
    opacity: .9;
}

/* Colunas genéricas */
#ev-footer .ev-footer-col {
    min-width: 0;
}

#ev-footer .ev-footer-title {
    font-size: 0.9rem;
    font-weight: 600;
    margin: 0 0 8px;
    color: var(--fg);
}

/* Listas de links */
#ev-footer .ev-footer-links {
    list-style: none;
    margin: 0;
    padding: 0;
}

#ev-footer .ev-footer-links li + li {
    margin-top: 4px;
}

#ev-footer a {
    color: var(--fg-subtle);
    text-decoration: none;
    font-size: 0.875rem;
    transition: color .16s ease, opacity .16s ease;
}

#ev-footer a:hover {
    color: var(--accent);
    opacity: 1;
}

/* Parte de baixo */
#ev-footer .ev-footer-bottom {
    padding-top: 12px;
    border-top: 1px solid rgba(255, 255, 255, .04);
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: space-between;
    align-items: center;
    font-size: 0.75rem;
    color: color-mix(in oklab, var(--fg-subtle) 80%, transparent);
}

#ev-footer .ev-footer-sign {
    opacity: .9;
}




/* Responsivo */
@media (min-width: 768px) {
    #ev-footer .ev-footer-inner {
        grid-template-columns: minmax(0, 1.2fr) repeat(3, minmax(0, 1fr));
        align-items: flex-start;
    }
}

/* =========================
   Footer EV (usa tokens core)
   ========================= */
#ev-footer {
    padding-block: 32px 16px;
    color: var(--fg-subtle);
    font-size: 0.875rem;
}

#ev-footer .ev-footer-inner {
    display: grid;
    grid-template-columns: minmax(0, 2fr) repeat(3, minmax(0, 1fr));
    gap: 24px;
    align-items: flex-start;
}

#ev-footer .ev-footer-brand img {
    max-height: 36px;
    width: auto;
    display: block;
    margin-bottom: 12px;
}

#ev-footer .ev-footer-text {
    line-height: 1.5;
    opacity: .9;
}

#ev-footer .ev-footer-title {
    font-size: 0.9rem;
    font-weight: 600;
    margin: 0 0 8px;
    color: var(--fg);
}

#ev-footer .ev-footer-links {
    list-style: none;
    margin: 0;
    padding: 0;
}

#ev-footer .ev-footer-links li + li {
    margin-top: 4px;
}

#ev-footer a {
    color: var(--fg-subtle);
    text-decoration: none;
    transition: color .16s ease, opacity .16s ease;
}

#ev-footer a:hover {
    color: var(--accent);
    opacity: 1;
}

#ev-footer .ev-footer-bottom {
    margin-top: 16px;
    padding-top: 12px;
    border-top: 1px solid var(--border-color);
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: space-between;
    align-items: center;
    font-size: 0.75rem;
    color: color-mix(in srgb, var(--fg-subtle) 80%, transparent);
}

/* Redes sociais no footer */
#ev-footer .ev-footer-social {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 10px;
}

#ev-footer .ev-footer-social li + li {
    margin-top: 0; /* sobrescreve a regra padrão de ev-footer-links */
}

#ev-footer .ev-footer-social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

#ev-footer .ev-footer-social-icon {
    width: 34px;
    height: 34px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--icon-bg);
    border: 1px solid var(--icon-bd);
    color: var(--fg);
    box-shadow: 0 1px 0 rgba(0, 0, 0, .35) inset;
    transition:
            background .18s ease,
            border-color .18s ease,
            color .18s ease,
            transform .18s cubic-bezier(.2, .8, .2, 1),
            box-shadow .18s ease;
}

#ev-footer .ev-footer-social-icon svg {
    width: 18px;
    height: 18px;
    display: block;
}

#ev-footer .ev-footer-social-link:hover .ev-footer-social-icon {
    background: var(--accent);
    border-color: var(--accent);
    color: #ffffff;
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, .45);
}

/* Mobile: grid empilhado */
@media (max-width: 768px) {
    #ev-footer .ev-footer-inner {
        grid-template-columns: 1fr;
    }
}


