/* ── Logo Wall v2 – Frontend ──────────────────────────────────────────────── */
/* Namespace .lw- isolado — zero conflito com temas/plugins existentes        */

/* ════════════════════════════════════════════════════════════════════════════
   GRID
   ════════════════════════════════════════════════════════════════════════════ */
.lw-grid {
    display: grid;
    grid-template-columns: repeat( var(--lw-cols, 6), 1fr );
    gap: var(--lw-gap, 32px);
    width: 100%;
    box-sizing: border-box;
    margin: 0; padding: 0; list-style: none;
}

/* ════════════════════════════════════════════════════════════════════════════
   CAROUSEL
   ════════════════════════════════════════════════════════════════════════════ */
.lw-carousel-wrap {
    position: relative;
    width: 100%;
    overflow: hidden;     /* clipping dos slides */
    box-sizing: border-box;
}

/* Zona de hover que não ativa as setas acidentalmente */
.lw-carousel-wrap:focus-within .lw-car-btn,
.lw-carousel-wrap:hover        .lw-car-btn { opacity: 1; pointer-events: auto; }

.lw-car-viewport {
    overflow: hidden;
    width: 100%;
}

.lw-car-track {
    display: flex;
    /* gap via padding nos itens para não cortar o scale no hover */
    transition: transform 0.45s cubic-bezier(.4,0,.2,1);
    will-change: transform;
    list-style: none;
    margin: 0; padding: 0;
}

/* Cada slide ocupa 1/var(--lw-car-vis) da largura do viewport */
.lw-carousel-wrap .lw-item {
    flex: 0 0 calc(100% / var(--lw-car-vis, 5));
    box-sizing: border-box;
    padding: 0 calc(var(--lw-gap, 32px) / 2);
}

/* ── Setas ──────────────────────────────────────────────────────────────── */
.lw-car-btn {
    position: absolute;
    top: 50%; transform: translateY(-50%);
    z-index: 10;
    width: 38px; height: 38px;
    border-radius: 50%;
    background: rgba(255,255,255,.92);
    border: 1.5px solid #e2e8f0;
    box-shadow: 0 2px 10px rgba(0,0,0,.12);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    opacity: 0;
    transition: opacity .2s, background .2s, transform .15s;
    padding: 0;
}
.lw-car-btn:hover { background: #fff; box-shadow: 0 4px 14px rgba(0,0,0,.18); }
.lw-car-btn:active { transform: translateY(-50%) scale(.94); }
.lw-car-btn svg { width: 18px; height: 18px; stroke: #334155; }
.lw-car-prev { left: 6px; }
.lw-car-next { right: 6px; }
.lw-car-btn.lw-car-hidden { display: none; }

/* ── Dots ──────────────────────────────────────────────────────────────── */
.lw-car-dots {
    display: flex; justify-content: center;
    gap: 6px; margin-top: 14px;
}
.lw-car-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: #cbd5e1; border: none; cursor: pointer;
    padding: 0; transition: background .2s, transform .2s;
}
.lw-car-dot-active { background: #2563eb; transform: scale(1.25); }

/* ════════════════════════════════════════════════════════════════════════════
   ITEM / CÉLULA (compartilhado: grid + carousel)
   ════════════════════════════════════════════════════════════════════════════ */
.lw-item {
    display: flex; align-items: center; justify-content: center;
    background: var(--lw-bg, transparent);
    border-radius: var(--lw-radius, 0);
    min-height: var(--lw-h, 80px);
    padding: 12px 16px;
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
}
.lw-logo-link {
    display: flex; align-items: center; justify-content: center;
    width: 100%; height: 100%;
    text-decoration: none; outline-offset: 4px;
    position: relative;
}

/* ── Imagem — normalização visual ──────────────────────────────────────── */
.lw-logo-img {
    display: block;
    width: 100%; max-width: 100%;
    height: var(--lw-h, 80px);
    max-height: var(--lw-h, 80px);
    object-fit: contain;
    object-position: center;
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
}

/* ════════════════════════════════════════════════════════════════════════════
   HOVER EFEITOS
   ════════════════════════════════════════════════════════════════════════════ */

/* ── zoom (legado + default) ─────────────────────────────────────────── */
.lw-item.lw-anim .lw-logo-img {
    transition: transform .28s cubic-bezier(.4,0,.2,1),
                opacity   .28s cubic-bezier(.4,0,.2,1),
                filter    .28s cubic-bezier(.4,0,.2,1);
}
.lw-item.lw-hover-zoom .lw-logo-img,
.lw-item.lw-anim:hover  .lw-logo-img { transform: scale(1.08); opacity: .88; }

/* ── grayscale ──────────────────────────────────────────────────────── */
.lw-item.lw-grayscale .lw-logo-img {
    filter: grayscale(100%) opacity(.6);
    transition: filter .3s, transform .28s;
}
.lw-item.lw-grayscale:hover .lw-logo-img {
    filter: grayscale(0%) opacity(1);
    transform: scale(1.05);
}

/* ── flip (gira 180° revelando o nome) ─────────────────────────────── */
.lw-item.lw-hover-flip { perspective: 800px; overflow: visible; }
.lw-flip-inner {
    width: 100%; height: var(--lw-h, 80px);
    position: relative;
    transform-style: preserve-3d;
    transition: transform .5s cubic-bezier(.4,0,.2,1);
}
.lw-item.lw-hover-flip:hover .lw-flip-inner { transform: rotateY(180deg); }
.lw-flip-front, .lw-flip-back {
    position: absolute; inset: 0;
    backface-visibility: hidden;
    display: flex; align-items: center; justify-content: center;
    border-radius: var(--lw-radius, 0);
}
.lw-flip-front { background: var(--lw-bg, transparent); }
.lw-flip-back {
    background: var(--lw-hover-cor, #2563eb);
    transform: rotateY(180deg);
}
.lw-flip-back-link,
.lw-flip-back-name {
    color: var(--lw-hover-txt, #ffffff);
    font-size: 13px; font-weight: 700;
    text-align: center; line-height: 1.3;
    padding: 8px; text-decoration: none;
    font-family: inherit;
}
.lw-flip-back-link:hover { text-decoration: underline; }

/* ── overlay (nome aparece sobre o logo no hover) ───────────────────── */
.lw-item.lw-hover-overlay .lw-logo-link { overflow: hidden; }
.lw-overlay-name {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    background: var(--lw-hover-cor, #2563eb);
    color: var(--lw-hover-txt, #ffffff);
    font-size: 13px; font-weight: 700;
    text-align: center; padding: 8px;
    opacity: 0;
    transition: opacity .28s ease;
    border-radius: var(--lw-radius, 0);
    line-height: 1.3;
    font-family: inherit;
}
.lw-item.lw-hover-overlay:hover .lw-overlay-name { opacity: 1; }
.lw-item.lw-hover-overlay:hover .lw-logo-img     { opacity: .15; transform: scale(.96); }
.lw-item.lw-hover-overlay .lw-logo-img { transition: opacity .28s, transform .28s; }

/* ════════════════════════════════════════════════════════════════════════════
   FILTRO POR CATEGORIA
   ════════════════════════════════════════════════════════════════════════════ */
.lw-filter {
    display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 24px;
}
.lw-filter-btn {
    padding: 6px 18px;
    border: 1.5px solid #e2e8f0; border-radius: 999px;
    background: #fff; color: #475569;
    font-size: 14px; font-weight: 500; cursor: pointer;
    transition: all .18s; font-family: inherit;
}
.lw-filter-btn:hover   { border-color: #2563eb; color: #2563eb; }
.lw-filter-btn.lw-active { background: #2563eb; border-color: #2563eb; color: #fff; }

/* ════════════════════════════════════════════════════════════════════════════
   ESTADOS
   ════════════════════════════════════════════════════════════════════════════ */
.lw-item.lw-hidden,
.lw-item[hidden] { display: none; }
.lw-empty { color: #94a3b8; font-style: italic; text-align: center; padding: 24px 0; }

/* ════════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
    .lw-grid { grid-template-columns: repeat( var(--lw-cols-t, 4), 1fr ); }
    .lw-carousel-wrap .lw-item { flex: 0 0 calc(100% / var(--lw-car-vis-t, 3)); }
}
@media (max-width: 600px) {
    .lw-grid {
        grid-template-columns: repeat( var(--lw-cols-m, 2), 1fr );
        gap: calc( var(--lw-gap, 32px) * 0.6 );
    }
    .lw-item { padding: 8px 10px; }
    .lw-carousel-wrap .lw-item { flex: 0 0 calc(100% / var(--lw-car-vis-m, 2)); }
    .lw-car-btn { opacity: 1; width: 32px; height: 32px; }
}

/* ── Acessibilidade: foco visível ──────────────────────────────────── */
.lw-logo-link:focus-visible,
.lw-car-btn:focus-visible,
.lw-filter-btn:focus-visible {
    outline: 3px solid #2563eb;
    outline-offset: 3px;
}
