/* PHDMA Impact Pages v3 — Frontend */
/* Scoped under .phdma-wrap to prevent ALL theme/plugin conflicts */

/* ── Reset scope: isolate our styles from theme overrides ── */
.phdma-wrap,
.phdma-wrap *,
.phdma-wrap *::before,
.phdma-wrap *::after {
    box-sizing: border-box;
}

/* ── Full-width wrapper ── */
.phdma-wrap {
    font-family: -apple-system, 'Segoe UI', Arial, sans-serif !important;
    color: #1a1a1a !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* ── Hide the title/heading block entirely ── */
.phdma-head {
    display: none !important;
}

/* ── Filter row ── */
.phdma-filters {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
    margin-bottom: 1.25rem !important;
    align-items: flex-end !important;
    width: 100% !important;
}

.phdma-f-block {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    flex: 1 1 180px !important;
    min-width: 140px !important;
    max-width: 340px !important;
}

.phdma-f-label {
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: .06em !important;
    color: #6b7280 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
}

/* ── Search input — override theme resets ── */
.phdma-f-search {
    position: relative !important;
}
.phdma-f-search svg {
    position: absolute !important;
    left: 9px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    color: #9ca3af !important;
    pointer-events: none !important;
    z-index: 1 !important;
}
.phdma-wrap input.phdma-search,
.phdma-wrap input.phdma-search:not([type='submit']) {
    width: 100% !important;
    padding: 9px 10px 9px 30px !important;
    border: 1px solid #d1d5db !important;
    border-radius: 6px !important;
    font-size: 13px !important;
    font-family: inherit !important;
    color: #1a1a1a !important;
    background: #fff !important;
    box-sizing: border-box !important;
    outline: none !important;
    box-shadow: none !important;
    transition: border-color .15s !important;
    height: auto !important;
    line-height: normal !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    margin: 0 !important;
}
.phdma-wrap input.phdma-search:focus {
    border-color: #6366f1 !important;
    box-shadow: 0 0 0 3px rgba(99,102,241,.1) !important;
    outline: none !important;
}

/* ── Select dropdowns — override theme resets ── */
.phdma-wrap select.phdma-cat,
.phdma-wrap select.phdma-year {
    width: 100% !important;
    padding: 9px 10px !important;
    border: 1px solid #d1d5db !important;
    border-radius: 6px !important;
    font-size: 13px !important;
    font-family: inherit !important;
    color: #1a1a1a !important;
    background: #fff !important;
    cursor: pointer !important;
    box-sizing: border-box !important;
    outline: none !important;
    box-shadow: none !important;
    transition: border-color .15s !important;
    appearance: auto !important;
    -webkit-appearance: auto !important;
    height: auto !important;
    line-height: normal !important;
    margin: 0 !important;
    display: block !important;
}
.phdma-wrap select.phdma-cat:focus,
.phdma-wrap select.phdma-year:focus {
    border-color: #6366f1 !important;
    outline: none !important;
}

/* ── Results count bar ── */
.phdma-bar {
    margin-bottom: 1rem !important;
}
.phdma-count {
    font-size: 13px !important;
    color: #9ca3af !important;
}

/* ── Grid — full width, 3-column default ── */
.phdma-grid {
    display: grid !important;
    gap: 18px !important;
    align-items: start !important;
    width: 100% !important;
}
.phdma-cols-2 { grid-template-columns: repeat(2, 1fr) !important; }
.phdma-cols-3 { grid-template-columns: repeat(3, 1fr) !important; }
.phdma-cols-4 { grid-template-columns: repeat(4, 1fr) !important; }

/* ── Card ── */
.phdma-card {
    background: #fff !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    transition: border-color .2s, box-shadow .2s !important;
    width: 100% !important;
}
.phdma-card:hover {
    border-color: #c7d2fe !important;
    box-shadow: 0 4px 16px rgba(99,102,241,.08) !important;
}

.phdma-card-img {
    width: 100% !important;
    aspect-ratio: 16/9 !important;
    overflow: hidden !important;
    background: #f3f4f6 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
.phdma-card-img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    transition: transform .3s !important;
    max-width: none !important;
}
.phdma-card:hover .phdma-card-img img {
    transform: scale(1.04) !important;
}
.phdma-no-img {
    color: #d1d5db !important;
}

.phdma-card-body {
    padding: 14px 14px 6px !important;
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 7px !important;
}
.phdma-card-meta {
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 7px !important;
}

/* Year badge on card */
.phdma-year-tag {
    display: inline-block !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    background: #eef2ff !important;
    color: #4f46e5 !important;
    padding: 2px 9px !important;
    border-radius: 20px !important;
    white-space: nowrap !important;
    border: none !important;
    line-height: 1.5 !important;
}
.phdma-sub {
    font-size: 11px !important;
    color: #9ca3af !important;
}

/* Card title — prevent theme h3 styles from overriding */
.phdma-wrap .phdma-card-title,
.phdma-wrap h3.phdma-card-title {
    font-size: 15px !important;
    font-weight: 600 !important;
    line-height: 1.35 !important;
    color: #111 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
}
.phdma-card-exc {
    font-size: 13px !important;
    color: #6b7280 !important;
    line-height: 1.6 !important;
    margin: 0 !important;
    flex: 1 !important;
}

.phdma-card-foot {
    padding: 10px 14px 14px !important;
}

/* Read More button — prevent theme <a> styles from overriding */
.phdma-wrap a.phdma-btn,
.phdma-wrap .phdma-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: #4f46e5 !important;
    border: 1px solid #c7d2fe !important;
    border-radius: 6px !important;
    padding: 6px 13px !important;
    text-decoration: none !important;
    background: transparent !important;
    transition: background .15s, border-color .15s !important;
    letter-spacing: .01em !important;
    cursor: pointer !important;
    line-height: normal !important;
    box-shadow: none !important;
}
.phdma-wrap a.phdma-btn:hover,
.phdma-wrap .phdma-btn:hover {
    background: #eef2ff !important;
    border-color: #a5b4fc !important;
    color: #3730a3 !important;
    text-decoration: none !important;
}

/* ── Loading spinner ── */
.phdma-loading {
    text-align: center !important;
    padding: 2rem !important;
}
.phdma-spin {
    display: inline-block !important;
    width: 26px !important;
    height: 26px !important;
    border: 3px solid #e5e7eb !important;
    border-top-color: #6366f1 !important;
    border-radius: 50% !important;
    animation: phdma-spin .7s linear infinite !important;
}
@keyframes phdma-spin {
    to { transform: rotate(360deg); }
}

/* ── Empty state ── */
.phdma-empty {
    padding: 2.5rem 1rem !important;
    text-align: center !important;
    color: #9ca3af !important;
    font-size: 15px !important;
    grid-column: 1 / -1 !important;
}

/* ── Responsive ── */
@media (max-width: 900px) {
    .phdma-cols-4,
    .phdma-cols-3 {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}
@media (max-width: 600px) {
    .phdma-filters {
        flex-direction: column !important;
    }
    .phdma-f-block {
        max-width: 100% !important;
    }
    .phdma-cols-4,
    .phdma-cols-3,
    .phdma-cols-2 {
        grid-template-columns: 1fr !important;
    }
}
