/* ── Europp Job Filter Dropdown ── */

.europp-filter-dropdown__select {
    display: block;
    width: 100%;
    box-sizing: border-box;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23515151' stroke-width='2.5' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 38px;
}

/* ── Europp Job Search Bar ── */

.europp-filter-search {
    display: flex;
    align-items: stretch;
}

.europp-filter-search__input {
    flex: 1;
    min-width: 0;
    box-sizing: border-box;
}

.europp-filter-search__btn {
    flex-shrink: 0;
    cursor: pointer;
}

/* ── Europp Job Filter Widget (legacy) ── */

.europp-job-filter-widget {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    background: var(--ejf-bg, #E0F1F3);
    border-radius: var(--ejf-radius, 8px);
    padding: var(--ejf-pt, 20px) var(--ejf-pr, 24px) var(--ejf-pb, 20px) var(--ejf-pl, 24px);
    font-family: Roboto, sans-serif;
}

.europp-filter__field {
    flex: 1 1 180px;
    min-width: 0;
}

.europp-filter__field--search {
    flex: 2 1 240px;
}

.europp-filter__select,
.europp-filter__input {
    width: 100%;
    height: 44px;
    padding: 0 14px;
    background: var(--ejf-input-bg, #FFFFFF);
    border: 1px solid var(--ejf-input-border, #D2D2D2);
    border-radius: 8px;
    font-family: Manrope, Roboto, sans-serif;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.6;
    color: #515151;
    appearance: none;
    -webkit-appearance: none;
    outline: none;
    transition: border-color 0.15s ease;
    box-sizing: border-box;
}

.europp-filter__select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23515151' stroke-width='2.5' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 38px;
    cursor: pointer;
}

.europp-filter__select:focus,
.europp-filter__input:focus {
    border-color: #0A2342;
}

.europp-filter__btn {
    flex: 0 0 auto;
    height: 44px;
    padding: 0 24px;
    background: var(--ejf-btn-bg, #F05822);
    color: var(--ejf-btn-color, #FFFFFF);
    border: none;
    border-radius: var(--ejf-btn-radius, 4px);
    font-family: Roboto, sans-serif;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.3px;
    cursor: pointer;
    transition: filter 0.15s ease;
    white-space: nowrap;
}

.europp-filter__btn:hover {
    filter: brightness(0.88);
}

@media (max-width: 640px) {
    .europp-job-filter-widget {
        flex-direction: column;
        align-items: stretch;
    }

    .europp-filter__field {
        flex: 1 1 100%;
    }

    .europp-filter__btn {
        width: 100%;
    }
}

/* ── Europp Job List Widget ── */

.europp-job-list-widget {
    position: relative;
    font-family: Roboto, sans-serif;
}

/* ── Filter bar ── */
.europp-job-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    background: var(--ejl-filter-bg, #E0F1F3);
    border-radius: var(--ejl-filter-radius, 8px);
    padding: var(--ejl-filter-pt, 20px) var(--ejl-filter-pr, 24px) var(--ejl-filter-pb, 20px) var(--ejl-filter-pl, 24px);
    margin-bottom: 30px;
}

.europp-job-filters__field {
    flex: 1 1 180px;
    min-width: 0;
}

.europp-job-filters__field--search {
    flex: 2 1 240px;
}

.europp-job-filters__select,
.europp-job-filters__input {
    width: 100%;
    height: 44px;
    padding: 0 14px;
    background: var(--ejl-input-bg, #FFFFFF);
    border: 1px solid var(--ejl-input-border, #D2D2D2);
    border-radius: 8px;
    font-family: Manrope, Roboto, sans-serif;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.6;
    color: #515151;
    appearance: none;
    -webkit-appearance: none;
    outline: none;
    transition: border-color 0.15s ease;
    box-sizing: border-box;
}

.europp-job-filters__select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23515151' stroke-width='2.5' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 38px;
    cursor: pointer;
}

.europp-job-filters__select:focus,
.europp-job-filters__input:focus {
    border-color: #0A2342;
}

.europp-job-filters__btn {
    flex: 0 0 auto;
    height: 44px;
    padding: 0 24px;
    background: #0A2342;
    color: #FFFFFF;
    border: none;
    border-radius: 4px;
    font-family: Roboto, sans-serif;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.3px;
    cursor: pointer;
    transition: background 0.15s ease;
    white-space: nowrap;
}

.europp-job-filters__btn:hover {
    background: #143160;
}

/* ── Jobs grid ── */
.europp-jobs-grid {
    display: grid;
    gap: var(--ejl-card-gap, 20px);
    grid-template-columns: 1fr;
}

.europp-jobs-grid--cols-2 {
    grid-template-columns: repeat(2, 1fr);
}

.europp-jobs-grid--cols-3 {
    grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 1024px) {
    .europp-jobs-grid--cols-3 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .europp-jobs-grid--cols-2,
    .europp-jobs-grid--cols-3 {
        grid-template-columns: 1fr;
    }

    .europp-job-filters {
        flex-direction: column;
        align-items: stretch;
    }

    .europp-job-filters__field {
        flex: 1 1 100%;
    }

    .europp-job-filters__btn {
        width: 100%;
        justify-content: center;
    }
}

/* ── Job card ── */
.europp-job-card {
    display: flex;
    flex-direction: column;
    background: var(--ejl-card-bg, #FFFFFF);
    border-radius: var(--ejl-card-radius, 8px);
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.12);
    padding: 24px;
    transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.europp-job-card:hover {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.16);
    transform: translateY(-2px);
}

.europp-job-card--expired {
    opacity: 0.6;
}

/* Top meta row: agency badge + date */
.europp-job-card__meta-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 12px;
}

.europp-job-card__agency-badge {
    font-family: Roboto, sans-serif;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.3px;
    color: var(--ejl-badge-color, #0A2342);
    background: var(--ejl-badge-bg, #E8EFF7);
    padding: 2px 8px;
    border-radius: 3px;
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 60%;
}

.europp-job-card__date {
    font-family: Roboto, sans-serif;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.3px;
    color: var(--ejl-date-color, #919191);
    background: #FAEBDF;
    padding: 2px 8px;
    border-radius: 3px;
    white-space: nowrap;
    flex-shrink: 0;
}

/* Contract type badge */
.europp-job-card__contract-badge {
    font-family: Roboto, sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.3px;
    color: var(--ejl-contract-badge-color, #F05822);
    background: var(--ejl-contract-badge-bg, #FFF1EC);
    padding: 2px 8px;
    border-radius: 3px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Salary */
.europp-job-card__salary {
    display: flex;
    align-items: center;
    gap: 6px;
    font-family: Roboto, sans-serif;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.6;
    color: var(--ejl-location-color, #7A7A7A);
    margin-bottom: 4px;
}

/* Title */
.europp-job-card__title {
    font-family: Roboto, sans-serif;
    font-size: var(--ejl-title-size, 18px);
    font-weight: 700;
    line-height: 1.4;
    color: var(--ejl-title-color, #000000);
    margin: 0 0 8px;
}

.europp-job-card__title a {
    color: inherit;
    text-decoration: none;
    transition: color 0.15s ease;
}

.europp-job-card__title a:hover {
    color: #F05822;
}

/* Location */
.europp-job-card__location {
    display: flex;
    align-items: center;
    gap: 6px;
    font-family: Roboto, sans-serif;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.6;
    color: var(--ejl-location-color, #7A7A7A);
    margin-bottom: 20px;
    flex: 1;
}

.europp-job-card__icon {
    flex-shrink: 0;
    color: inherit;
}

/* Apply button */
.europp-job-card__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 12px 16px;
    background: var(--ejl-btn-bg, #F05822);
    color: var(--ejl-btn-color, #FFFFFF);
    border: 1px solid var(--ejl-btn-bg, #F05822);
    border-radius: var(--ejl-btn-radius, 4px);
    font-family: Roboto, sans-serif;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.15s ease, border-color 0.15s ease;
    box-sizing: border-box;
    margin-top: auto;
}

.europp-job-card__btn:hover {
    background: var(--ejl-btn-hover-bg, #d44c1b);
    border-color: var(--ejl-btn-hover-bg, #d44c1b);
    color: var(--ejl-btn-color, #FFFFFF);
}

/* Empty state */
.europp-jobs-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 48px 20px;
    color: #868686;
    font-family: Roboto, sans-serif;
    font-size: 16px;
}

/* ── Pagination ── */
.europp-jobs-pagination-wrap {
    margin-top: 30px;
}

.europp-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
}

.europp-pagination__btn,
.europp-pagination__num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 8px;
    background: #F9FAFB;
    border: 1px solid #EBEBEB;
    border-radius: 4px;
    font-family: Roboto, sans-serif;
    font-size: 14px;
    font-weight: 600;
    color: #515151;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
    line-height: 1;
}

.europp-pagination__btn:hover,
.europp-pagination__num:hover {
    background: #E0F1F3;
    border-color: #0A2342;
    color: #0A2342;
}

.europp-pagination__num--active {
    background: var(--ejl-pagination-bg, #0A2342);
    border-color: var(--ejl-pagination-bg, #0A2342);
    color: var(--ejl-pagination-color, #FFFFFF);
    cursor: default;
    pointer-events: none;
}

.europp-pagination__ellipsis {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    color: #868686;
    font-size: 14px;
    font-family: Roboto, sans-serif;
}

/* ── Loading overlay ── */
.europp-jobs-loading {
    display: none;
    position: absolute;
    inset: 0;
    background: rgba(255, 255, 255, 0.75);
    border-radius: var(--ejl-card-radius, 8px);
    align-items: center;
    justify-content: center;
    z-index: 10;
}

.europp-job-list-widget.is-loading .europp-jobs-loading {
    display: flex;
}

.europp-job-list-widget.is-loading .europp-jobs-grid,
.europp-job-list-widget.is-loading .europp-jobs-pagination-wrap {
    pointer-events: none;
    opacity: 0.4;
}

@keyframes europp-spin {
    to { transform: rotate(360deg); }
}

.europp-jobs-loading__spinner {
    width: 36px;
    height: 36px;
    border: 3px solid #EBEBEB;
    border-top-color: #F05822;
    border-radius: 50%;
    animation: europp-spin 0.7s linear infinite;
}
