/* ==========================================================================
   Recommend Jobs Block — Frontend Styles
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=Fraunces:opsz,wght@9..144,400;9..144,600;9..144,700&display=swap');

/* ── CSS Custom Properties ── */
.recommend-jobs-block {
    --rjb-accent:       #2563eb;
    --rjb-pin:          #f59e0b;
    --rjb-bg:           #ffffff;
    --rjb-card-bg:      #ffffff;
    --rjb-border:       #e5e7eb;
    --rjb-shadow:       0 1px 3px rgba(0,0,0,.07), 0 4px 16px rgba(0,0,0,.04);
    --rjb-shadow-hover: 0 4px 12px rgba(0,0,0,.10), 0 12px 32px rgba(0,0,0,.07);
    --rjb-text-primary: #111827;
    --rjb-text-secondary: #6b7280;
    --rjb-text-muted:   #9ca3af;
    --rjb-radius:       14px;
    --rjb-radius-sm:    8px;
    --rjb-font-display: 'Fraunces', Georgia, serif;
    --rjb-font-body:    'DM Sans', system-ui, sans-serif;
    --rjb-transition:   .22s cubic-bezier(.4,0,.2,1);

    font-family: var(--rjb-font-body);
    color: var(--rjb-text-primary);
    background: var(--rjb-bg);
}

/* ── Block Title ── */
.recommend-jobs-block__title,
.rjb-block-title {
    font-family: var(--rjb-font-display);
    font-size: clamp(1.5rem, 2.5vw, 2rem);
    font-weight: 700;
    color: var(--rjb-text-primary);
    margin: 0 0 1.75rem;
    letter-spacing: -0.02em;
    line-height: 1.2;
    position: relative;
    padding-bottom: .875rem;
}

.recommend-jobs-block__title::after,
.rjb-block-title::after {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 2.5rem;
    height: 3px;
    background: var(--rjb-accent);
    border-radius: 2px;
}

/* ── Grid ── */
.recommend-jobs-block__grid,
.rjb-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr;
}

.recommend-jobs-block__grid--cols-2,
.rjb-grid--cols-2 {
    grid-template-columns: 1fr;
}

@media (min-width: 640px) {
    .recommend-jobs-block__grid--cols-2,
    .rjb-grid--cols-2 {
        grid-template-columns: repeat(2, 1fr);
    }
}

.recommend-jobs-block__grid--cols-1,
.rjb-grid--cols-1 {
    grid-template-columns: 1fr;
    max-width: 700px;
}

/* ── Card ── */
.recommend-jobs-block__card,
.rjb-card {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    background: var(--rjb-card-bg);
    border: 1px solid var(--rjb-border);
    border-radius: var(--rjb-radius);
    padding: 1.25rem;
    box-shadow: var(--rjb-shadow);
    transition:
        box-shadow var(--rjb-transition),
        border-color var(--rjb-transition),
        transform var(--rjb-transition);
    overflow: hidden;
}

.recommend-jobs-block__card:hover,
.rjb-card:hover {
    box-shadow: var(--rjb-shadow-hover);
    border-color: color-mix(in srgb, var(--rjb-accent) 30%, var(--rjb-border));
    transform: translateY(-2px);
}

/* Pinned card accent */
.recommend-jobs-block__card--pinned,
.rjb-card--pinned {
    border-color: color-mix(in srgb, var(--rjb-pin) 40%, var(--rjb-border));
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--rjb-pin) 4%, white),
        white 60%
    );
}

.recommend-jobs-block__card--pinned::before,
.rjb-card--pinned::before {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    border-radius: inherit;
    border-left: 3px solid var(--rjb-pin);
}

/* ── Pin Badge ── */
.recommend-jobs-block__pin-badge,
.rjb-pin-badge {
    position: absolute;
    top: .75rem;
    right: .75rem;
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    background: var(--rjb-pin);
    color: #fff;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    padding: .25rem .55rem;
    border-radius: 999px;
    line-height: 1;
    box-shadow: 0 2px 6px color-mix(in srgb, var(--rjb-pin) 50%, transparent);
}

/* ── Logo ── */
.recommend-jobs-block__logo-link {
    display: block;
    flex-shrink: 0;
    text-decoration: none;
    border-radius: var(--rjb-radius-sm);
    overflow: hidden;
    transition: opacity var(--rjb-transition);
}

.recommend-jobs-block__logo-link:hover {
    opacity: .85;
}

.recommend-jobs-block__logo,
.rjb-logo {
    display: block;
    width: 76px;
    height: 76px;
    object-fit: cover;
    border-radius: var(--rjb-radius-sm);
    border: 1px solid var(--rjb-border);
    background: #f3f4f6;
}

.recommend-jobs-block__logo-placeholder,
.rjb-logo-placeholder {
    width: 76px;
    height: 76px;
    border-radius: var(--rjb-radius-sm);
    border: 1px solid var(--rjb-border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--rjb-font-display);
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--rjb-accent);
    background: color-mix(in srgb, var(--rjb-accent) 8%, white);
    letter-spacing: -0.02em;
    flex-shrink: 0;
    user-select: none;
}

/* ── Logo wrap (editor) ── */
.rjb-card__logo-wrap {
    flex-shrink: 0;
}

/* ── Card Info ── */
.recommend-jobs-block__info,
.rjb-card__body {
    flex: 1;
    min-width: 0;
    padding-right: 2.5rem; /* space for pin badge */
}

/* ── Position / Title ── */
.recommend-jobs-block__position-link {
    text-decoration: none;
}

.recommend-jobs-block__position-link:hover .recommend-jobs-block__position {
    text-decoration: underline;
    text-decoration-color: var(--rjb-accent);
    text-underline-offset: 2px;
}

.recommend-jobs-block__position,
.rjb-card__position {
    font-family: var(--rjb-font-display);
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--rjb-accent);
    margin: 0 0 .2rem;
    line-height: 1.3;
    letter-spacing: -0.01em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    cursor: pointer;
    transition: text-decoration-color var(--rjb-transition);
}

.rjb-card__position:hover {
    text-decoration: underline;
    text-underline-offset: 2px;
}

/* ── Company ── */
.recommend-jobs-block__company,
.rjb-card__company {
    font-size: .88rem;
    font-weight: 600;
    color: var(--rjb-text-primary);
    margin: 0 0 .3rem;
}

/* ── Location ── */
.recommend-jobs-block__location,
.rjb-card__location {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    font-size: .8rem;
    color: var(--rjb-text-secondary);
    margin: 0 0 .6rem;
}

.recommend-jobs-block__location svg,
.rjb-card__location svg {
    flex-shrink: 0;
    opacity: .7;
}

/* ── Description ── */
.recommend-jobs-block__description,
.rjb-card__desc {
    font-size: .8rem;
    color: var(--rjb-text-muted);
    margin: 0 0 .75rem;
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ── CTA Link ── */
.recommend-jobs-block__cta,
.rjb-card__cta {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    font-size: .8rem;
    font-weight: 600;
    color: var(--rjb-accent);
    text-decoration: none;
    letter-spacing: .01em;
    transition: gap var(--rjb-transition), opacity var(--rjb-transition);
}

.recommend-jobs-block__cta:hover,
.rjb-card__cta:hover {
    gap: .5rem;
    opacity: .8;
}

/* ── Empty State ── */
.recommend-jobs-block--empty {
    padding: 2rem;
    text-align: center;
    color: var(--rjb-text-muted);
    border: 1px dashed var(--rjb-border);
    border-radius: var(--rjb-radius);
}

/* ── Editor-specific ── */
.recommend-jobs-block--editor .rjb-loading {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: 2rem;
    color: var(--rjb-text-secondary);
    font-size: .9rem;
}
