/* Job Vacancy frontend styles.
   All rules are descendants of `.jv-widget` so theme CSS rarely beats us on specificity.
   No !important is used. */

/* ---------- Wrapper reset (resets inherited theme styles) ---------- */
.jv-widget.jv-widget {
    --jv-gap: 20px;
    --jv-radius: 12px;
    box-sizing: border-box;
    color: #1a1a1a;
    font-family: inherit;
    line-height: 1.5;
    letter-spacing: normal;
    text-align: left;
    -webkit-font-smoothing: antialiased;
}
.jv-widget.jv-widget * { box-sizing: border-box; }
.jv-widget.jv-widget a { text-decoration: none; }

/* ---------- List grid ---------- */
.jv-widget .job-vacancy-list {
    display: grid;
    gap: var(--jv-gap);
    margin: 0;
    padding: 0;
    list-style: none;
}
.jv-widget .job-vacancy-list[data-columns="1"] { grid-template-columns: 1fr; }
.jv-widget .job-vacancy-list[data-columns="2"] { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.jv-widget .job-vacancy-list[data-columns="3"] { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.jv-widget .job-vacancy-list[data-columns="4"] { grid-template-columns: repeat(4, minmax(0, 1fr)); }

@media (max-width: 1024px) {
    .jv-widget .job-vacancy-list[data-columns="3"],
    .jv-widget .job-vacancy-list[data-columns="4"] {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 600px) {
    .jv-widget .job-vacancy-list { grid-template-columns: 1fr; }
}

/* ---------- Card ---------- */
.jv-widget .job-vacancy-card {
    background: #fff;
    border: 1px solid #e3e3e3;
    border-radius: var(--jv-radius);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    margin: 0;
    padding: 0;
    transition: box-shadow .2s ease, transform .2s ease;
}
.jv-widget .job-vacancy-card.is-featured { border-color: #f5b400; }
.jv-widget .job-vacancy-card:hover {
    box-shadow: 0 8px 24px rgba(0, 0, 0, .08);
    transform: translateY(-2px);
}

.jv-widget .job-vacancy-card .job-vacancy-card__thumb {
    display: block;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    margin: 0;
}
.jv-widget .job-vacancy-card .job-vacancy-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    margin: 0;
    padding: 0;
    border: 0;
}

.jv-widget .job-vacancy-card .job-vacancy-card__body {
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
}
.jv-widget .job-vacancy-card .job-vacancy-card__badge {
    align-self: flex-start;
    background: #f5b400;
    color: #1a1a1a;
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: .5px;
    line-height: 1.4;
}
.jv-widget .job-vacancy-card .job-vacancy-card__title {
    margin: 0;
    padding: 0;
    font-size: 18px;
    line-height: 1.3;
    font-weight: 600;
    color: #1a1a1a;
}
.jv-widget .job-vacancy-card .job-vacancy-card__title a {
    color: #1a1a1a;
    text-decoration: none;
}
.jv-widget .job-vacancy-card .job-vacancy-card__title a:hover { color: #2563eb; }

.jv-widget .job-vacancy-card .job-vacancy-card__company {
    margin: 0;
    padding: 0;
    font-size: 14px;
    color: #555;
    font-weight: 500;
}

.jv-widget .job-vacancy-card .job-vacancy-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    list-style: none;
    margin: 4px 0;
    padding: 0;
}
.jv-widget .job-vacancy-card .job-vacancy-card__meta-item {
    background: #f3f4f6;
    color: #444;
    padding: 2px 10px;
    border-radius: 999px;
    font-size: 12px;
    text-transform: capitalize;
    line-height: 1.6;
    list-style: none;
}

.jv-widget .job-vacancy-card .job-vacancy-card__salary {
    margin: 0;
    padding: 0;
    font-size: 14px;
    font-weight: 600;
    color: #16a34a;
}

.jv-widget .job-vacancy-card .job-vacancy-card__excerpt {
    margin: 4px 0 0;
    padding: 0;
    font-size: 14px;
    color: #555;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.jv-widget .job-vacancy-card .job-vacancy-card__actions {
    margin-top: auto;
    padding: 12px 0 0;
    display: flex;
    gap: 8px;
}
.jv-widget .job-vacancy-card .job-vacancy-card__view,
.jv-widget .job-vacancy-card .job-vacancy-card__apply {
    flex: 1;
    text-align: center;
    padding: 10px 14px;
    border-radius: 8px;
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.4;
    box-sizing: border-box;
}
.jv-widget .job-vacancy-card .job-vacancy-card__view {
    border: 1px solid #d1d5db;
    background: #fff;
    color: #1a1a1a;
}
.jv-widget .job-vacancy-card .job-vacancy-card__view:hover { background: #f9fafb; color: #1a1a1a; }
.jv-widget .job-vacancy-card .job-vacancy-card__apply {
    background: #2563eb;
    color: #fff;
    border: 1px solid transparent;
}
.jv-widget .job-vacancy-card .job-vacancy-card__apply:hover { background: #1d4ed8; color: #fff; }

/* ---------- Single Job page wrapper (default template) ---------- */
.jv-widget.jv-single-page {
    max-width: 880px;
    margin: 0 auto;
    box-sizing: border-box;
    padding-top: 60px;
    padding-bottom: 60px;
}

/* ---------- Archive page wrapper (default template) ---------- */
.jv-widget.jv-archive-page {
    max-width: 1140px;
    margin: 0 auto;
    box-sizing: border-box;
    padding-top: 60px;
    padding-bottom: 60px;
}
.jv-widget.jv-archive-page .jv-archive-page__header {
    margin: 0 0 24px;
    padding: 0;
}
.jv-widget.jv-archive-page .jv-archive-page__title {
    margin: 0 0 8px;
    padding: 0;
    font-size: 32px;
    line-height: 1.2;
    color: #1a1a1a;
    font-weight: 700;
}
.jv-widget.jv-archive-page .jv-archive-page__description {
    margin: 0;
    font-size: 15px;
    color: #555;
}

/* Pagination (renders WP's paginate_links output) */
.jv-widget.jv-archive-page .jv-archive-page__pagination {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: center;
    margin: 32px 0 0;
    padding: 0;
}
.jv-widget.jv-archive-page .jv-archive-page__pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 10px;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    background: #fff;
    color: #1a1a1a;
    text-decoration: none;
    font-size: 14px;
    line-height: 1;
    box-sizing: border-box;
}
.jv-widget.jv-archive-page .jv-archive-page__pagination .page-numbers:hover {
    background: #f3f4f6;
    color: #1a1a1a;
}
.jv-widget.jv-archive-page .jv-archive-page__pagination .page-numbers.current {
    background: #2563eb;
    border-color: transparent;
    color: #fff;
}
.jv-widget.jv-archive-page .jv-archive-page__pagination .page-numbers.dots {
    border-color: transparent;
    background: transparent;
}

/* ---------- Single Job ---------- */
.jv-widget.job-vacancy-single {
    display: flex;
    flex-direction: column;
    gap: 24px;
}
.jv-widget .job-vacancy-single__thumb {
    margin: 0;
    padding: 0;
    border-radius: 12px;
    overflow: hidden;
    background: #f3f4f6;
    /* aspect-ratio: 16 / 9; */
}
.jv-widget .job-vacancy-single__thumb img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    margin: 0;
    padding: 0;
    border: 0;
}
.jv-widget .job-vacancy-single__header {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin: 0;
    padding: 0;
}
.jv-widget .job-vacancy-single__badge {
    align-self: flex-start;
    background: #f5b400;
    color: #1a1a1a;
    font-size: 12px;
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: .5px;
    line-height: 1.4;
}
.jv-widget .job-vacancy-single__title {
    margin: 0;
    padding: 0;
    font-size: 32px;
    line-height: 1.2;
    color: #1a1a1a;
    font-weight: 700;
}
.jv-widget .job-vacancy-single__company {
    margin: 0;
    padding: 0;
    font-size: 18px;
    color: #555;
}
.jv-widget .job-vacancy-single .job-vacancy-single__meta {
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 8px 16px;
    background: #f9fafb;
    padding: 16px 20px;
    border-radius: 12px;
    margin: 0;
}
.jv-widget .job-vacancy-single .job-vacancy-single__meta dt {
    margin: 0;
    padding: 0;
    font-weight: 600;
    color: #374151;
}
.jv-widget .job-vacancy-single .job-vacancy-single__meta dd {
    margin: 0;
    padding: 0;
    color: #1a1a1a;
}
.jv-widget .job-vacancy-single__content { line-height: 1.7; color: #1a1a1a; }
.jv-widget .job-vacancy-single__actions {
    display: flex;
    gap: 12px;
    margin: 0;
    padding: 0;
}
.jv-widget .job-vacancy-single__actions .job-vacancy-single__apply {
    padding: 10px 20px;
    background: #007fbf;
    color: #fff;
    border-radius: 16px;
    text-decoration: none;
    font-weight: 500;
    line-height: 1.4;
    border: 1px solid transparent;
}
.jv-widget .job-vacancy-single__actions .job-vacancy-single__apply:hover {
    background: #1d4ed8;
    color: #fff;
}

/* ---------- Empty state ----------
   When the empty state is the child of the .job-vacancy-list grid,
   collapse the grid back to block layout so the empty state spans the
   full width and the inner flex column (icon above text) renders
   correctly instead of being squeezed into one grid track. */
.jv-widget .job-vacancy-list:has(> .job-vacancy-empty) {
    display: block;
}

.jv-widget .job-vacancy-empty {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    color: #6b7280;
    padding: 56px 24px;
    text-align: center;
    margin: 0;
    box-sizing: border-box;
}
.jv-widget .job-vacancy-empty svg {
    width: 48px;
    height: 48px;
    color: #d1d5db;
    flex: none;
}
.jv-widget .job-vacancy-empty p,
.jv-widget .job-vacancy-empty span {
    margin: 0;
    padding: 0;
    font-size: 14px;
}

/* ---------- Job Ads Column widget ---------- */
.jv-widget.job-vacancy-ads-column {
    display: flex;
    flex-direction: column;
    gap: var(--jv-ad-gap, 16px);
    width: 100%;
    margin: 0;
    padding: 0;
    list-style: none;
}

.jv-widget .job-vacancy-ad-box {
    position: relative;
    background: #fff;
    border: 1px solid #e3e3e3;
    border-radius: 12px;
    padding: 16px;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
    transition: box-shadow .2s ease, transform .2s ease;
}
.jv-widget .job-vacancy-ad-box:hover {
    box-shadow: 0 6px 20px rgba(0, 0, 0, .06);
    transform: translateY(-1px);
}
.jv-widget .job-vacancy-ad-box.is-featured { border-color: #f5b400; }

.jv-widget .job-vacancy-ad-box .job-vacancy-ad-box__badge {
    position: absolute;
    top: 12px;
    right: 12px;
    background: #f5b400;
    color: #1a1a1a;
    font-size: 10px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: .5px;
    line-height: 1.4;
}

.jv-widget .job-vacancy-ad-box .job-vacancy-ad-box__title {
    margin: 0;
    padding: 0 60px 0 0;
    font-size: 15px;
    line-height: 1.35;
    font-weight: 600;
    color: #1a1a1a;
}
.jv-widget .job-vacancy-ad-box .job-vacancy-ad-box__title a {
    color: #1a1a1a;
    text-decoration: none;
}
.jv-widget .job-vacancy-ad-box .job-vacancy-ad-box__title a:hover { color: #2563eb; }

.jv-widget .job-vacancy-ad-box .job-vacancy-ad-box__company,
.jv-widget .job-vacancy-ad-box .job-vacancy-ad-box__location {
    margin: 0;
    padding: 0;
    font-size: 13px;
    color: #555;
    line-height: 1.4;
}
.jv-widget .job-vacancy-ad-box .job-vacancy-ad-box__location { color: #6b7280; }

.jv-widget .job-vacancy-ad-box .job-vacancy-ad-box__type {
    align-self: flex-start;
    background: #f3f4f6;
    color: #444;
    padding: 2px 10px;
    border-radius: 999px;
    font-size: 11px;
    text-transform: capitalize;
    line-height: 1.6;
}

.jv-widget .job-vacancy-ad-box .job-vacancy-ad-box__salary {
    margin: 0;
    padding: 0;
    font-size: 13px;
    font-weight: 600;
    color: #16a34a;
}

.jv-widget .job-vacancy-ad-box .job-vacancy-ad-box__cta {
    margin-top: 6px;
    align-self: flex-start;
    background: #2563eb;
    color: #fff;
    padding: 8px 14px;
    border-radius: 8px;
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.4;
    border: 1px solid transparent;
}
.jv-widget .job-vacancy-ad-box .job-vacancy-ad-box__cta:hover {
    background: #1d4ed8;
    color: #fff;
}

/* Compact variant */
.jv-widget .job-vacancy-ad-box.job-vacancy-ad-box--compact { padding: 12px; gap: 4px; }
.jv-widget .job-vacancy-ad-box.job-vacancy-ad-box--compact .job-vacancy-ad-box__title { font-size: 14px; }
.jv-widget .job-vacancy-ad-box.job-vacancy-ad-box--compact .job-vacancy-ad-box__cta { padding: 6px 10px; font-size: 12px; }
