/* =============================================================================
   Resource Library — Redesign
   Variables, filter sidebar, resource cards, featured resource, pagination.
   ============================================================================= */

/* ── Colour & design tokens ────────────────────────────────────────────────── */
:root {
    --ilcn-teal:           #2A5D5D;   /* type labels, links, CTA text          */
    --ilcn-teal-mid:       #5E9889;   /* checkbox border, year inputs           */
    --ilcn-hover-bg:       #EDF4F3;   /* card hover background                 */
    --ilcn-card-border:    #DAE7E7;   /* card top/bottom border                */
    --ilcn-author-color:   #707070;   /* author / source byline                */
    --ilcn-title-color:    #000;   /* card title                            */
    --ilcn-body-color:     #333333;   /* body text                             */
    --ilcn-bg-light:       #F4F8F8;   /* sidebar background                    */
    --ilcn-transition:     0.18s ease;
    --ilcn-blue:            #2E7AA6;
    --ilcn-soft-gray:       #E7E7E7;
}

/* ── Page layout: sidebar + listing ────────────────────────────────────────── */
.resource-library-layout {
    display: grid;
    grid-template-columns: 270px 1fr;
    gap: 0 24px;
    align-items: start;
    max-width: 1190px;
    margin: 0 auto;
    padding: 40px 15px;
}

@media ( max-width: 900px ) {
    .resource-library-layout {
        grid-template-columns: 1fr;
    }
}

#resource-keyword-search{
    padding: 16px 24px;
    border:0px;
}
/* ── Filter sidebar ─────────────────────────────────────────────────────────── */
.resource-filter-sidebar {
    background: #fff;
    position: sticky;
    top: 24px;
}

.filter-header {
    padding: 0 0 12px;
}

.filter-clear-all {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--ilcn-teal);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color var(--ilcn-transition);
}
.filter-clear-all:hover {
    border-bottom-color: var(--ilcn-teal);
}

.filter-divider {
    border: none;
    border-top: 1px solid var(--ilcn-card-border);
    margin: 0 0 20px;
}

/* Group title */
.filter-group {
    margin-bottom: 20px;
}

.filter-group-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    background: none;
    border: none;
    padding: 0 0 12px;
    cursor: pointer;
    text-align: left;
}

.filter-group-title {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--ilcn-title-color);
    margin: 0;
}
#filter-group-year .filter-group-title{
    margin-bottom: 16px;
}

/* Collapse chevron */
.filter-toggle-icon {
    width: 10px;
    height: 10px;
    border-right: 2px solid var(--ilcn-teal);
    border-bottom: 2px solid var(--ilcn-teal);
    transform: rotate(45deg);
    transition: transform var(--ilcn-transition);
    flex-shrink: 0;
    margin-left: 8px;
}
[aria-expanded="false"] .filter-toggle-icon {
    transform: rotate(-45deg);
}

.filter-country-list.is-collapsed {
    display: none;
}
/* Collapsible list */
.filter-checkbox-list {
    list-style: none;
    padding: 0;
    margin: 0 0 8px;
    overflow: hidden;
    transition: max-height 0.25s ease;
}
.filter-checkbox-list.is-collapsed {
    display: none;
}

/* Checkbox row */
.filter-checkbox-label {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 6px 0;
    font-size: 0.9rem;
    color: var(--ilcn-body-color);
    cursor: pointer;
    line-height: 1.4;
}
.filter-checkbox-label input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}
.filter-checkbox-custom {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border: 1.25px solid var(--ilcn-teal-mid);
    border-radius: 3px;
    flex-shrink: 0;
    transition: background var(--ilcn-transition), border-color var(--ilcn-transition);
}
.filter-checkbox-label input[type="checkbox"]:checked + .filter-checkbox-custom {
    background: var(--ilcn-teal-mid);
    border-color: var(--ilcn-teal-mid);
}
.filter-checkbox-label input[type="checkbox"]:checked + .filter-checkbox-custom::after {
    content: '';
    display: block;
    width: 5px;
    height: 9px;
    border-right: 2px solid #fff;
    border-bottom: 2px solid #fff;
    transform: rotate(45deg) translate(-1px, -1px);
}
.filter-checkbox-label:hover .filter-checkbox-custom {
    border-color: var(--ilcn-teal);
}

/* Year range */
.filter-year-range {
    display: flex;
    align-items: flex-end;
    gap: 8px;
}
.filter-year-field {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.filter-year-field label {
    font-size: 0.78rem;
    color: var(--ilcn-author-color);
}
.filter-year-field input[type="number"] {
    width: 100%;
    padding: 8px 10px;
    border: 1.25px solid var(--ilcn-teal-mid);
    border-radius: 4px;
    font-size: 0.9rem;
    color: var(--ilcn-body-color);
    -moz-appearance: textfield;
}
.filter-year-field input[type="number"]::-webkit-inner-spin-button,
.filter-year-field input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: none;
}
.filter-year-field input[type="number"]:focus {
    outline: none;
    border-color: var(--ilcn-teal);
}
.filter-year-sep {
    font-size: 0.9rem;
    color: var(--ilcn-author-color);
    padding-bottom: 10px;
}

/* Country nested groups */
.filter-letter-group {
    margin-bottom: 4px;
}
.filter-letter-hidden {
    display: none;
}
.filter-letter-toggle {
    display: flex;
    align-items: center;
    background: none;
    border: none;
    padding: 2px 0;
    cursor: pointer;
    width: 100%;
    text-align: left;
    gap: 0;
}
.filter-letter-label {
    font-weight: 600;
    flex: 1;
}
.filter-country-sublist {
    padding-left: 28px;
}

.filter-show-more {
    background: none;
    border: none;
    color: var(--ilcn-teal);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    padding: 6px 0;
    text-decoration: underline;
}

/* ── Resource listing: top bar ──────────────────────────────────────────────── */
.resource-listing-topbar {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 24px;
}

.resource-search-wrap {
    display: flex;
    align-items: center;
    flex: 1;
    min-width: 200px;
    border: 1px solid var(--ilcn-soft-gray);
    border-radius: 8px;
    overflow: hidden;
    background: #fff;
}
.resource-keyword-search {
    flex: 1;
    border: none;
    padding: 16px 24px;
    font-size: 1rem;
    color: var(--ilcn-body-color);
    background: transparent;
}
.resource-keyword-search:focus {
    outline: none;
}
.resource-search-btn {
    border: none;
    padding: 16px;
    
    cursor: pointer;
    background: var(--ilcn-blue);
    color:white;
    heigh:100%;
    border-radius: 5px;
    display: flex;
    align-items: center;
}
.resource-search-btn svg {
    width: 18px;
    height: 18px;
}

.resource-listing-meta {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-shrink: 0;
}

.resource-results-count {
    font-size: 0.9rem;
    color: black;
    white-space: nowrap;
}

.resource-sort-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.9rem;
}
.resource-sort-wrap label {
    color: black;
    white-space: nowrap;
}
.resource-sort-select {
    border: 0;
    border-radius: 4px;
    padding: 6px 28px 6px 10px;
    font-size: 0.875rem;
    color: black;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%232A5D5D' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 10px center;
    -webkit-appearance: none;
    cursor: pointer;
}
.resource-sort-select:focus {
    outline: none;
    border-color: var(--ilcn-teal);
}

/* ── Full-width topbar above the 2-column layout ── */
.resource-topbar-wrap {
    max-width: 1190px;
    margin: 90px auto 0 auto;
    padding: 0px 15px 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.resource-topbar-row {
    display: flex;
    align-items: center;
    gap: 16px;
}

.resource-topbar-search .resource-search-wrap {
    width: 100%;
}

.resource-topbar-meta {
    justify-content: space-between;
    display: flex;
    align-items: center;
}


/* ── Resource cards ─────────────────────────────────────────────────────────── */
.resource-cards-list {
    position: relative;
}
.resource-cards-list.is-loading {
    opacity: 0.5;
    pointer-events: none;
}

.resource-card {
    border-top: 1px solid var(--ilcn-card-border);
    transition: background var(--ilcn-transition);
}
.resource-card:last-child {
    border-bottom: 1px solid var(--ilcn-card-border);
}
.resource-card:hover {
    background: var(--ilcn-hover-bg);
}

.resource-card-inner {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 32px;
    padding: 24px 30px;
}

.resource-card-content {
    flex: 1;
    min-width: 0;
}

.resource-card-type {
    display: block;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: var(--ilcn-teal);
    text-transform: uppercase;
    margin-bottom: 8px;
}

.resource-card-title {
    font-size: 1.1rem;
    font-weight: 500;
    color: var(--ilcn-title-color);
    margin: 0 0 8px;
    line-height: 1.35;
}
.resource-card-title a {
    color: inherit;
    text-decoration: none;
}
.resource-card-title a:hover {
    color: var(--ilcn-teal);
}

.resource-card-author {
    font-size: 0.875rem;
    color: var(--ilcn-author-color);
    margin: 0 0 16px;
}

.resource-card-cta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.8125rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    color: var(--ilcn-teal);
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: opacity var(--ilcn-transition);
}
.resource-card-cta:hover {
    opacity: 0.75;
    color: var(--ilcn-teal);
    text-decoration: none;
}

.cta-icon {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}

/* Card image */
.resource-card-image {
    flex-shrink: 0;
    width: 220px;
}
.resource-card-image img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    border-radius: 2px;
}

@media ( max-width: 640px ) {
    .resource-card-image {
        width: 120px;
    }
}

/* ── Loading state ───────────────────────────────────────────────────────────── */
.resources-not-found {
    padding: 40px 0;
    color: var(--ilcn-author-color);
    font-size: 0.95rem;
}

/* ── Pagination ─────────────────────────────────────────────────────────────── */
.resource-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    padding: 40px 0 16px;
}

.resource-pagination-btn {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1.5px solid var(--ilcn-card-border);
    background: #fff;
    font-size: 1.2rem;
    cursor: pointer;
    color: var(--ilcn-teal);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--ilcn-transition), border-color var(--ilcn-transition);
}
.resource-pagination-btn:hover:not(:disabled) {
    background: var(--ilcn-hover-bg);
    border-color: var(--ilcn-teal-mid);
}
.resource-pagination-btn:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}
/* Next button filled per design */
.resource-pagination-next {
    background: var(--ilcn-teal);
    border-color: var(--ilcn-teal);
    color: #fff;
}
.resource-pagination-next:hover:not(:disabled) {
    background: #1e4444;
    border-color: #1e4444;
}

.resource-pagination-label {
    font-size: 1rem;
    color: var(--ilcn-body-color);
    min-width: 48px;
    text-align: center;
}
.resource-pagination-sep {
    margin: 0 4px;
    color: var(--ilcn-author-color);
}


.page-template-page-resources-library .banner{
    padding:230px 0 85px 0;
    background: url('../images/background-resources-library.webp') no-repeat center center transparent;
    background-size: cover;
    position: relative;
}
.page-template-page-resources-library .overlay{
    position: absolute;
    bottom: 0;
    left: 0;
    width:100%;
    height: 100%;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.00) 0%, rgba(0, 0, 0, 0.30) 70%, #000 100%);
        z-index: 1;
}
.page-template-page-resources-library .banner .wrapper{
    max-width: 1160px;
    margin: auto;
    width: 100%;
    position: relative;
    z-index: 5;
    padding: 0 15px;
}
.page-template-page-resources-library .banner .eyebrow{
    font-weight: bold;
    font-size: 1rem;
    color: white;
}
.page-template-page-resources-library .banner h1{
    color: white;
    font-size: 2.813rem;
        margin-top: 5px;
    margin-bottom: 0px;
}

/* ── Featured resource ──────────────────────────────────────────────────────── */
.featured-resource-section {
    
    padding: 0;
}
.featured-resource-section .container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 24px;
}

.featured-resource-block {
    background: var(--ilcn-hover-bg);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    min-height: 340px;
        max-width: 1160px;
    margin: 100px auto 50px;

}

@media ( max-width: 768px ) {
    .featured-resource-block {
        grid-template-columns: 1fr;
    }
    .featured-resource-image {
        order: -1;
    }
}


.featured-resource-content {
    padding: 44px 85px 50px 70px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.featured-resource-badges {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
}

.featured-resource-badge {
    display: inline-block;
    background: var(--ilcn-teal);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 5px 14px;
    border-radius: 100px;
}

.featured-resource-type {
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ilcn-teal);
}

.featured-resource-title {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--ilcn-title-color);
    line-height: 1.25;
    margin: 0 0 12px;
}

.featured-resource-author {
    font-size: 0.875rem;
    color: var(--ilcn-author-color);
    margin: 0 0 16px;
}

.featured-resource-description {
    font-size: 0.9375rem;
    color: var(--ilcn-body-color);
    line-height: 1.6;
    margin: 0 0 28px;
}

.featured-resource-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid rgba(51, 51, 51, 0.20);
    background: white;
    padding: 10px 50px;
    font-size: 0.8125rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ilcn-body-color);
    text-decoration: none;
    border-radius: 5px;
    align-self: flex-start;
}
.featured-resource-cta:hover {
        opacity: .8;
    text-decoration: none;
}

.featured-resource-image {
    overflow: hidden;
}
.featured-resource-image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
@media ( max-width: 1024px ) {
    
    .filter-group-toggle {
        /* Force collapsed state visually */
    }
    
    /*.filter-toggle-icon {
        transform: rotate( -45deg );
    }*/
}


@media all and (max-width: 767px){
    .page-template-page-resources-library .banner {
        padding: 130px 0 55px 0;
    }
    .featured-resource-block{
            margin: 70px auto 50px;
    }
    .featured-resource-content {
        padding: 40px 35px 50px 35px;
    }
    .resource-card-inner{
        padding: 24px 24px;
    }
}