/* wp-plugin/open-jobs/assets/open-jobs.css */

/* El wrap es un panel blanco unificado: queda legible y "uniforme" sobre
   cualquier fondo de página (verde, oscuro, blanco). Las tarjetas internas
   se distinguen con un gris muy sutil sin doblar la sombra. */
.oj-wrap {
    --oj-bg: #ffffff;
    --oj-fg: #1a1a1a;
    --oj-muted: #5b6571;
    --oj-border: #e5e7eb;
    --oj-accent: #2563eb;
    --oj-warn-bg: #fff4d6;
    --oj-warn-fg: #8a5b00;
    --oj-card-bg: #f9fafb;
    --oj-card-hover-bg: #f1f3f6;
    --oj-radius: 12px;
    --oj-shadow: 0 1px 2px rgba(0,0,0,0.05), 0 6px 22px rgba(0,0,0,0.07);
    background: var(--oj-bg);
    color: var(--oj-fg);
    padding: 1.25rem 1.5rem 1.5rem;
    border-radius: var(--oj-radius);
    box-shadow: var(--oj-shadow);
    font-family: inherit;
}

li.oj-row {
    margin-left: 0px;
}

.oj-wrap, .oj-wrap * { box-sizing: border-box; }

.oj-meta {
    margin: 0;
    color: var(--oj-muted);
    font-size: .85rem;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .4rem;
    white-space: nowrap;
}
.oj-meta-sep { color: var(--oj-border); }

.oj-meta { margin: 0 0 1.25rem; }

.oj-badge {
    display: inline-block;
    padding: .15rem .55rem;
    border-radius: 999px;
    font-size: .75rem;
    font-weight: 600;
}
.oj-badge--warn { background: var(--oj-warn-bg); color: var(--oj-warn-fg); }

/* Cards */
.oj-cards {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: .65rem;
}
.oj-card {
    background: var(--oj-card-bg);
    border: 1px solid var(--oj-border);
    border-radius: 8px;
    padding: var(--oj-card-padding, .9rem 1.05rem);
    position: relative;
    transition: background-color .15s ease;
}
.oj-card:hover { background: var(--oj-card-hover-bg); }

.oj-card__title {
    display: block;
    font-weight: 600;
    font-size: 1.05rem;
    color: #1a1a1a;
    text-decoration: none;
    margin-bottom: .35rem;
    padding-right: 5rem;
}
.oj-wrap .oj-card__title:visited { color: #1a1a1a; }
.oj-wrap .oj-card__title:hover { color: var(--oj-accent); }

.oj-card__desc {
    margin: .35rem 0 .25rem;
    color: var(--oj-muted);
    font-size: .9rem;
    line-height: 1.45;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.oj-card__meta {
    list-style: none;
    margin: .5rem 0 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: .35rem .9rem;
    color: var(--oj-muted);
    font-size: .85rem;
}
.oj-card__meta li { display: inline-flex; align-items: center; gap: .35rem; }
.oj-icon { font-size: .9em; line-height: 1; }

.oj-card__date {
    position: absolute;
    top: .9rem;
    right: 1.05rem;
    color: var(--oj-muted);
    font-size: .8rem;
}

.oj-empty-tab {
    color: var(--oj-muted);
    background: var(--oj-card-bg);
    border: 1px dashed var(--oj-border);
    border-radius: 8px;
    padding: 1rem;
    text-align: center;
}
.oj-empty-tab a {
    color: var(--oj-accent);
    text-decoration: underline;
}
.oj-empty-tab a:hover { text-decoration: none; }

/* Modo compacto: padding más fino, oculta descripción */
.oj--compact .oj-card { padding: .55rem .8rem; }
.oj--compact .oj-card__desc { display: none; }

@media (max-width: 480px) {
    .oj-wrap { padding: 1rem 1.1rem 1.1rem; }
    .oj-card__title { padding-right: 0; }
    .oj-card__date {
        position: static;
        display: block;
        margin-top: .4rem;
    }
}

/* === BASE: helpers compartidos por skins === */
.oj-card__desc--clamp2 {
    -webkit-line-clamp: 2;
}

/* === SKIN: grid === */
.oj-wrap[data-skin="grid"] {
    background: transparent;
    box-shadow: none;
    padding: 0;
}
.oj-wrap[data-skin="grid"] .oj-meta {
    margin: 0 0 1rem;
}
.oj-grid {
    list-style: none; margin: 0; padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1rem;
}
.oj-wrap[data-skin="grid"] .oj-card--grid {
    background: #ffffff;
    border: 1px solid var(--oj-border);
    border-top: 3px solid var(--oj-accent);
    border-radius: 10px;
    padding: var(--oj-card-padding, 1rem 1.1rem .85rem);
    box-shadow: 0 1px 4px rgba(0,0,0,.04);
    position: relative;
}
.oj-wrap[data-skin="grid"] .oj-card--grid .oj-card__title {
    padding-right: 0;
}
.oj-wrap[data-skin="grid"] .oj-card__date--inline {
    position: static;
    display: block;
    margin-top: .55rem;
    font-size: .75rem;
}
.oj-wrap[data-skin="grid"].oj--compact .oj-card--grid { padding: .7rem .85rem; }
.oj-wrap[data-skin="grid"].oj--compact .oj-card__desc { display: none; }

/* === SKIN: magazine === */
.oj-wrap[data-skin="magazine"] .oj-hero {
    background: linear-gradient(135deg, var(--oj-accent), color-mix(in srgb, var(--oj-accent) 60%, #7c3aed));
    color: #ffffff;
    border-radius: 12px;
    padding: 1.5rem 1.75rem 1.6rem;
    position: relative;
    margin-bottom: 1rem;
}
.oj-wrap[data-skin="magazine"] .oj-hero__title {
    display: block;
    color: #ffffff;
    text-decoration: none;
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 1.2;
    margin: 0 0 .5rem;
    padding-right: 7rem;
}
.oj-wrap[data-skin="magazine"] .oj-hero__title:hover { text-decoration: underline; }
.oj-wrap[data-skin="magazine"] .oj-hero__desc {
    color: rgba(255,255,255,.92);
    line-height: 1.45;
    margin: 0 0 .75rem;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.oj-wrap[data-skin="magazine"] .oj-hero .oj-card__meta {
    color: rgba(255,255,255,.92);
}
.oj-wrap[data-skin="magazine"] .oj-hero__date {
    position: absolute;
    bottom: 1rem;
    right: 1.25rem;
    font-size: .8rem;
    color: rgba(255,255,255,.85);
}
.oj-mag-grid {
    list-style: none; margin: 0; padding: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .75rem;
}
.oj-wrap[data-skin="magazine"] .oj-card--mag {
    background: var(--oj-card-bg);
    border: 1px solid var(--oj-border);
    border-radius: 8px;
    padding: var(--oj-card-padding, .85rem 1rem);
    position: relative;
}
.oj-wrap[data-skin="magazine"] .oj-card--mag .oj-card__title {
    padding-right: 0;
}
.oj-wrap[data-skin="magazine"].oj--compact .oj-hero { padding: 1rem 1.2rem; }
.oj-wrap[data-skin="magazine"].oj--compact .oj-hero__desc { -webkit-line-clamp: 2; }
.oj-wrap[data-skin="magazine"].oj--compact .oj-card--mag .oj-card__meta { display: none; }
@media (max-width: 640px) {
    .oj-mag-grid { grid-template-columns: 1fr; }
    .oj-wrap[data-skin="magazine"] .oj-hero__title { padding-right: 0; }
}

/* === SKIN: list === */
.oj-wrap[data-skin="list"] .oj-list {
    list-style: none; margin: 0; padding: 0;
}
.oj-wrap[data-skin="list"] .oj-row {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .65rem .25rem;
    border-bottom: 1px solid var(--oj-border);
}
.oj-wrap[data-skin="list"] .oj-row:last-child { border-bottom: 0; }
.oj-wrap[data-skin="list"] .oj-row__title {
    color: #1a1a1a;
    text-decoration: none;
    font-weight: 600;
    font-size: .95rem;
    flex: 0 1 auto;     /* ancho natural, puede encoger si toca */
    min-width: 0;
    margin-right: .5rem;
}
.oj-wrap[data-skin="list"] .oj-row__title:hover { color: var(--oj-accent); }
.oj-wrap[data-skin="list"] .oj-row__chips {
    color: var(--oj-muted);
    font-size: .85rem;
    flex: 0 1 auto;     /* ancho natural, puede encoger */
    min-width: 0;
}
.oj-wrap[data-skin="list"] .oj-row__date {
    color: var(--oj-muted);
    font-size: .8rem;
    flex: 0 0 auto;
    margin-left: auto;  /* empuja la fecha hasta la derecha */
    text-align: right;
    min-width: 4rem;
}
.oj-wrap[data-skin="list"].oj--compact .oj-row { padding: .4rem .2rem; }
@media (max-width: 640px) {
    .oj-wrap[data-skin="list"] .oj-row { flex-wrap: wrap; }
    .oj-wrap[data-skin="list"] .oj-row__title { flex: 1 1 100%; min-width: 0; }
    .oj-wrap[data-skin="list"] .oj-row__chips { flex: 1; }
}

/* === SKIN: tiles === */
.oj-wrap[data-skin="tiles"] {
    background: transparent;
    box-shadow: none;
    padding: 0;
}
.oj-wrap[data-skin="tiles"] .oj-meta { margin: 0 0 1rem; color: var(--oj-muted); }
.oj-tiles {
    list-style: none; margin: 0; padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: .65rem;
}
.oj-tile {
    border-radius: 8px;
    padding: 1rem 1.1rem;
    position: relative;
    min-height: 9rem;
    display: flex;
    flex-direction: column;
    gap: .35rem;
}
.oj-tile__title {
    font-weight: 700;
    font-size: 1.1rem;
    line-height: 1.2;
    color: inherit;
    text-decoration: none;
    padding-right: 4rem;
}
.oj-tile__title:hover { text-decoration: underline; }
.oj-tile__chips {
    font-size: .85rem;
    margin: auto 0 0;
    opacity: .9;
}
.oj-tile__date {
    position: absolute;
    top: 1rem;
    right: 1.1rem;
    font-size: .75rem;
    opacity: .8;
}
.oj-tile--presencial { background: #fbbf24; color: #1a1a1a; }
.oj-tile--hibrido    { background: #f472b6; color: #ffffff; }
.oj-tile--remoto     { background: #60a5fa; color: #ffffff; }
.oj-tile--unknown    { background: #94a3b8; color: #ffffff; }
.oj-wrap[data-skin="tiles"].oj--compact .oj-tile { padding: .7rem .85rem; min-height: 7rem; }
