/* ============================================================
   Processos Seletivos ESCT — frontend (sem dependências externas)
   ============================================================ */
.ps-container {
    --ps-primary:    #15506b;
    --ps-open:       #1f8a4c;
    --ps-open-tint:  #e7f5ed;
    --ps-open-text:  #166534;
    --ps-closed:     #64748b;
    --ps-closed-tint:#eef1f4;
    --ps-surface:    #ffffff;
    --ps-border:     #e3e8ec;
    --ps-text:       #1f2a33;
    --ps-muted:      #5d6b76;

    max-width: 1180px;
    margin: 0 auto;
    padding: 8px 0 32px;
    color: var(--ps-text);
    font-family: inherit;
    box-sizing: border-box;
}
.ps-container *, .ps-container *::before, .ps-container *::after { box-sizing: border-box; }

/* ---- grid ---- */
.ps-grid-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 22px;
}

/* ---- card ---- */
.ps-card-pub {
    display: flex;
    flex-direction: column;
    background: var(--ps-surface);
    border: 1px solid var(--ps-border);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 1px 2px rgba(16, 36, 48, .05);
    transition: transform .18s ease, box-shadow .18s ease;
}
.ps-card-pub.is-aberto { border-top: 3px solid var(--ps-open); }
.ps-card-pub.is-encerrado { border-top: 3px solid var(--ps-closed); }
.ps-card-pub:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 24px rgba(16, 36, 48, .10);
}

/* ---- imagem + badge ---- */
.ps-card-img {
    position: relative;
    background: #f4f6f8;
    aspect-ratio: 16 / 9;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px;
}
.ps-card-img img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}
.ps-card-pub.is-encerrado .ps-card-img img {
    filter: grayscale(1);
    opacity: .55;
}

.ps-status-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .01em;
    padding: 5px 12px;
    border-radius: 999px;
    line-height: 1;
}
.is-aberto .ps-status-badge {
    color: var(--ps-open-text);
    background: var(--ps-open-tint);
    box-shadow: inset 0 0 0 1px rgba(31, 138, 76, .25);
}
.is-encerrado .ps-status-badge {
    color: var(--ps-closed);
    background: var(--ps-closed-tint);
    box-shadow: inset 0 0 0 1px rgba(100, 116, 139, .25);
}

/* ---- corpo ---- */
.ps-card-body {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 18px 20px 20px;
    flex: 1;
}
.ps-edital-num {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--ps-primary);
}
.ps-card-titulo {
    margin: 0;
    font-size: 18px;
    line-height: 1.3;
    font-weight: 700;
    color: var(--ps-text);
}
.ps-card-prazo {
    margin: 0;
    font-size: 13.5px;
    color: var(--ps-muted);
}
.ps-card-prazo strong { color: var(--ps-text); }

/* ---- ações ---- */
.ps-card-acoes {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: auto;
    padding-top: 14px;
}
.ps-btn {
    flex: 1 1 auto;
    text-align: center;
    font-size: 14px;
    font-weight: 600;
    padding: 10px 16px;
    border-radius: 8px;
    text-decoration: none;
    cursor: pointer;
    transition: background .15s ease, color .15s ease, border-color .15s ease;
    white-space: nowrap;
}
.ps-btn-edital {
    color: var(--ps-primary);
    background: #fff;
    border: 1.5px solid var(--ps-primary);
}
.ps-btn-edital:hover { background: var(--ps-primary); color: #fff; }

.ps-btn-inscrever {
    color: #fff;
    background: var(--ps-open);
    border: 1.5px solid var(--ps-open);
}
.ps-btn-inscrever:hover { background: #19743f; border-color: #19743f; }

.ps-btn-disabled {
    color: var(--ps-muted);
    background: var(--ps-closed-tint);
    border: 1.5px solid transparent;
    cursor: not-allowed;
}

.ps-btn:focus-visible {
    outline: 3px solid rgba(21, 80, 107, .45);
    outline-offset: 2px;
}

/* ---- estado vazio ---- */
.ps-empty {
    text-align: center;
    padding: 48px 20px;
    border: 1px dashed var(--ps-border);
    border-radius: 12px;
    background: #fafbfc;
}
.ps-empty p { margin: 0 0 6px; font-size: 17px; font-weight: 600; color: var(--ps-text); }
.ps-empty span { font-size: 14px; color: var(--ps-muted); }

@media (prefers-reduced-motion: reduce) {
    .ps-card-pub, .ps-btn { transition: none; }
    .ps-card-pub:hover { transform: none; }
}
