/**
 * Prefeitura – Serviços Widget
 * style.css – Estilos do Grid e Cards de Serviços
 *
 * Organização:
 *  1. Reset e Base
 *  2. Grid Wrapper
 *  3. Grid Layout
 *  4. Card
 *  5. Link (área clicável)
 *  6. Ícones (FontAwesome + SVG inline)
 *  7. Título
 *  8. Serviços em Destaque
 *  9. Efeitos Hover
 * 10. Estado Vazio (painel)
 * 11. Responsividade (fallback sem Elementor)
 */

/* ==========================================================================
   1. Reset e Base
   ========================================================================== */

.psw-grid-wrapper *,
.psw-grid-wrapper *::before,
.psw-grid-wrapper *::after {
    box-sizing: border-box;
}

/* ==========================================================================
   2. Grid Wrapper
   ========================================================================== */

.psw-grid-wrapper {
    width: 100%;
    margin: 0 auto;
}

/* ==========================================================================
   3. Grid Layout
   ========================================================================== */

.psw-grid {
    display: grid;
    /* Valor padrão – sobrescrito pelo Elementor via CSS inline */
    grid-template-columns: repeat(6, 1fr);
    gap: 16px;
}

/* ==========================================================================
   4. Card
   ========================================================================== */

.psw-servico-card {
    /* Valores padrão – a maioria é controlada pelo Elementor */
    background-color: #ffffff;
    border-radius: 8px;
    overflow: hidden;
    position: relative;
    /* Transição controlada via Elementor; definimos fallback aqui */
    transition: all 0.3s ease;
    /* Garante que o card ocupe a altura inteira da célula do grid */
    display: flex;
    flex-direction: column;
}

/* ==========================================================================
   5. Link (área clicável = card inteiro)
   ========================================================================== */

.psw-servico-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    text-decoration: none;
    color: inherit;
    /* Padding controlado pelo Elementor; fallback: */
    padding: 20px 12px;
    /* Ocupa toda a altura do card */
    flex: 1;
    height: 100%;
    /* Remove o outline padrão do browser e substitui por um acessível */
    outline-offset: 2px;
}

.psw-servico-link:hover,
.psw-servico-link:focus {
    text-decoration: none;
    color: inherit;
}

/* Foco acessível (teclado / leitores de tela) */
.psw-servico-link:focus-visible {
    outline: 3px solid #1a6aaa;
    border-radius: 6px;
}

/* ==========================================================================
   6. Ícones
   ========================================================================== */

.psw-icone {
    display: flex;
    align-items: center;
    justify-content: center;
    /* Margem e cor controladas pelo Elementor; fallbacks: */
    margin-bottom: 10px;
    color: #1a6aaa;
    line-height: 1;
    /* Transição também herdada do card */
    transition: color 0.3s ease, transform 0.3s ease;
}

/* ── FontAwesome ── */
.psw-icone-fa i {
    /* Tamanho controlado pelo Elementor; fallback: */
    font-size: 36px;
    color: inherit;
    display: block;
    line-height: 1;
}

/* ── SVG Inline ── */
.psw-icone-svg svg {
    /* Dimensões controladas pelo Elementor; fallback: */
    width: 48px;
    height: 48px;
    /* Permite controle de cor via CSS (SVG deve usar fill="currentColor") */
    fill: currentColor;
    color: inherit;
    display: block;
    flex-shrink: 0;
}

/* SVG como <img> (fallback quando arquivo não pode ser lido inline) */
.psw-icone-svg img {
    width: 48px;
    height: 48px;
    object-fit: contain;
    display: block;
}

/* ==========================================================================
   7. Título do Serviço
   ========================================================================== */

.psw-servico-titulo {
    /* Tipografia controlada pelo Elementor; fallbacks: */
    font-size: 14px;
    font-weight: 500;
    line-height: 1.4;
    color: #333333;
    margin: 0;
    padding: 0;
    transition: color 0.3s ease;
    /* Quebra palavras longas para não estourar o card */
    word-break: break-word;
    hyphens: auto;
}

/* ==========================================================================
   8. Serviços em Destaque (.servico-destaque)
   ========================================================================== */

.psw-servico-card.servico-destaque {
    /* Cor de fundo e borda controladas pelo Elementor; fallbacks: */
    background-color: #f0f7ff;
    border: 2px solid #1a6aaa;
    box-shadow: 0 4px 16px rgba(26, 106, 170, 0.15);
}

.psw-servico-card.servico-destaque .psw-icone {
    color: #1a6aaa;
}

.psw-servico-card.servico-destaque .psw-icone-fa i {
    /* Tamanho maior no destaque (sobrescrito pelo Elementor) */
    font-size: 48px;
}

.psw-servico-card.servico-destaque .psw-icone-svg svg {
    width: 52px;
    height: 52px;
}

.psw-servico-card.servico-destaque .psw-servico-titulo {
    color: #1a4f80;
    font-weight: 600;
}

/* ==========================================================================
   9. Efeitos Hover
   Aplicados via classe no .psw-grid-wrapper (selecionado no Elementor)
   ========================================================================== */

/* ── Nenhum ── */
.psw-hover-none .psw-servico-card:hover {
    /* sem transformação */
}

/* ── Levantar (translateY) ── */
.psw-hover-levantar .psw-servico-card:hover {
    transform: translateY(-5px);
}

/* ── Sombra Extra ── */
.psw-hover-sombra .psw-servico-card:hover {
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18);
}

/* ── Escala (zoom) ── */
.psw-hover-escala .psw-servico-card:hover {
    transform: scale(1.04);
}

/* ── Levantar + Sombra ── */
.psw-hover-levantar-sombra .psw-servico-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.16);
}

/* Hover para destaques (sombra mais intensa) */
.psw-hover-levantar .psw-servico-card.servico-destaque:hover,
.psw-hover-levantar-sombra .psw-servico-card.servico-destaque:hover {
    box-shadow: 0 12px 36px rgba(26, 106, 170, 0.28);
}

/* ==========================================================================
   10. Estado Vazio (mensagem no painel/editor)
   ========================================================================== */

.psw-no-servicos {
    padding: 24px;
    text-align: center;
    border: 2px dashed #cccccc;
    border-radius: 8px;
    color: #888888;
    font-size: 14px;
    width: 100%;
}

/* ==========================================================================
   11. Responsividade Fallback (para uso fora do Elementor ou reset)
   O Elementor injeta o CSS responsivo automaticamente via add_responsive_control.
   Estes estilos servem de fallback.
   ========================================================================== */

@media screen and (max-width: 1024px) {
    .psw-grid:not([style*="grid-template-columns"]) {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media screen and (max-width: 767px) {
    .psw-grid:not([style*="grid-template-columns"]) {
        grid-template-columns: repeat(2, 1fr);
    }

    .psw-icone-fa i {
        font-size: 28px;
    }

    .psw-icone-svg svg {
        width: 36px;
        height: 36px;
    }

    .psw-servico-titulo {
        font-size: 12px;
    }
}

@media screen and (max-width: 480px) {
    .psw-grid:not([style*="grid-template-columns"]) {
        gap: 10px;
    }
}
