/* === SECTION: faz a área do plugin ocupar a altura inteira da página (height: 100vh)
   Mantém o conteúdo centralizado em largura (mesma largura de antes) === */
   .ap-fullwidth-wrapper {
    width: 100%;
    padding: 24px 0 40px; /* espaço superior/inferior da seção */
    box-sizing: border-box;
    display: flex;
    align-items: flex-start; /* se quiser centralizar verticalmente, mude para "center" */
    min-height: 100vh; /* ocupa a altura inteira da viewport */
    background: transparent;
}

/* container interno centralizado (mantém a largura igual à versão anterior) */
.ap-fullwidth-wrapper .ap-container {
    max-width: 1200px; /* igual ao que estava */
    margin: 0 auto;
    width: 100%;
    padding: 0 20px; /* margem interna lateral */
}

/* === TRUNCATE: limitar o texto de descrição no card e mostrar reticências === */
.ap-card-excerpt {
    margin: 0 0 18px;
    color: #666;
    font-size: 14px;
    text-align: center;
    flex: 0 0 auto;

    /* multiline truncate with ellipsis */
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3; /* mostra até 3 linhas — ajuste se quiser mais/menos */
    overflow: hidden;
    text-overflow: ellipsis;
    word-break: break-word; /* quebra palavras longas para evitar overflow */
}

/* Se preferir limitar a 2 linhas, troque -webkit-line-clamp: 3 -> 2 */

/* Basic grid + controls */
.ap-controls {
    margin-bottom:18px;
    display:flex;
    align-items:center;
    gap:12px;
}
.ap-filter-label { font-weight:600; color:#333; }
.ap-filter-select { padding:8px 10px; border-radius:8px; border:1px solid #ddd; }

/* Grid */
.ap-grid {
    display: grid;
    gap: 26px;
}

/* columns */
.ap-grid-cols-1 { grid-template-columns: 1fr; }
.ap-grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
.ap-grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
.ap-grid-cols-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 980px) {
    .ap-grid { grid-template-columns: repeat(2,1fr) !important; }
}
@media (max-width: 600px) {
    .ap-grid { grid-template-columns: 1fr !important; }
}

/* Card */
.ap-card {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 6px 18px rgba(11,20,40,0.06);
    overflow: hidden;
    display:flex;
    flex-direction:column;
    min-height: 340px;
    transition: transform .18s ease, box-shadow .18s ease;
}
.ap-card:hover { transform: translateY(-6px); box-shadow: 0 20px 40px rgba(6,12,34,0.12); }

/* Top banner with color and curved corners like image */
.ap-card-top {
    height: 110px;
    display:flex;
    align-items:flex-end;
    justify-content:center;
    padding:14px;
    border-bottom-left-radius: 18px;
    border-bottom-right-radius: 18px;
}
.ap-card-top-inner {
    background: #fff;
    padding:10px;
    border-radius:10px;
    display:flex;
    align-items:center;
    justify-content:center;
    min-width:120px;
}
.ap-card-top img {
    max-height: 72px;
    max-width: 100%;
    object-fit:contain;
}

/* banner variations */
.ap-banner-blue { background: linear-gradient(90deg,#2f8ef7,#1fb6ff); }
.ap-banner-green { background: linear-gradient(90deg,#90c93e,#7fc241); }
.ap-banner-purple { background: linear-gradient(90deg,#7b61ff,#9f7bff); }

/* Body */
.ap-card-body {
    padding: 20px;
    display:flex;
    flex-direction:column;
    flex:1;
}
.ap-card-title {
    margin:0 0 8px;
    font-size:18px;
    text-align:center;
}
.ap-card-excerpt {
    margin:0 0 18px;
    color:#666;
    font-size:14px;
    text-align:center;
    flex:0 0 auto;
}

/* Button */
.ap-card-actions {
    margin-top:auto;
    display:flex;
    justify-content:center;
}
.ap-btn-visualizar {
    background:#ff6b00; /* laranja */
    color:#fff;
    border:none;
    padding:10px 28px;
    border-radius:26px;
    cursor:pointer;
    font-weight:700;
    box-shadow: 0 6px 0 rgba(0,0,0,0.04);
    transition: transform .12s ease;
}
.ap-btn-visualizar:active { transform: translateY(1px); }

/* Modal */
.ap-modal {
    position:fixed;
    inset:0;
    display:none;
    align-items:center;
    justify-content:center;
    z-index:99999;
}
.ap-modal[aria-hidden="false"] { display:flex; }

.ap-modal-backdrop {
    position:absolute;
    inset:0;
    background:rgba(0,0,0,0.5);
}

.ap-modal-inner {
    position:relative;
    z-index:2;
    max-width:920px;
    width:92%;
    background:#fff;
    border-radius:12px;
    box-shadow:0 20px 60px rgba(6,12,34,0.35);
    overflow:hidden;
    animation: ap-modal-in .16s ease;
}

@keyframes ap-modal-in {
    from { transform: translateY(8px); opacity:0; }
    to { transform: translateY(0); opacity:1; }
}

.ap-modal-content { padding:22px; }

.ap-modal-close {
    position:absolute;
    right:12px;
    top:8px;
    background:transparent;
    border:none;
    font-size:28px;
    cursor:pointer;
}

/* header inside modal */
.ap-modal-header {
    display:flex;
    gap:18px;
    align-items:center;
    margin-bottom:12px;
}
.ap-modal-title { margin:0; font-size:20px; }
.ap-modal-img img { max-height:70px; max-width:140px; object-fit:contain; }

/* body/description */
.ap-modal-body {
    margin-bottom:16px;
    color:#333;
    line-height:1.6;
}

/* footer links */
.ap-modal-footer {
    display:flex;
    gap:12px;
    flex-wrap:wrap;
}
.ap-link-btn {
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:10px 16px;
    border-radius:10px;
    background:#0b74de;
    color:#fff;
    text-decoration:none;
    font-weight:700;
    box-shadow: 0 6px 0 rgba(0,0,0,0.06);
}

/* small badges/icons inside buttons */
.ap-link-btn svg { height:18px; width:auto; display:block; }
.ap-link-btn.secondary { background:#111; }

/* Admin list visual handle */
.ap-drag-handle { font-weight:700; color:#777; }

/* Responsive tweaks */
@media (max-width:600px) {
    .ap-card { min-height: 300px; }
    .ap-card-top { height:100px; }
}
