/* ================================================================
   Sourdosphère — jobs.css
   ================================================================ */

/* ── Hero ─────────────────────────────────────────────────────── */
.jobs-page { display: flex; flex-direction: column; gap: 1.1rem; }

.jobs-hero {
    background: var(--green-dark);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    display: flex; align-items: center; justify-content: space-between; gap: 1rem;
    flex-wrap: wrap;
}
.jobs-hero__title { font-size: 1.3rem; font-weight: 700; color: #fff; margin: 0 0 0.25rem; }
.jobs-hero__sub   { font-size: 0.85rem; color: rgba(255,255,255,0.65); margin: 0; }

/* ── Filtres ──────────────────────────────────────────────────── */
.jobs-filters {
    background: var(--white);
    border: 1px solid var(--gray-border);
    border-radius: var(--radius-lg);
    padding: 0.9rem 1rem;
    display: flex; align-items: center; gap: 0.65rem; flex-wrap: wrap;
}
.jobs-filters__search {
    flex: 1; min-width: 180px;
    position: relative; display: flex; align-items: center;
}
.jobs-filters__search svg { position: absolute; left: 10px; color: var(--gray-mid); flex-shrink: 0; }
.jobs-filters__search-input {
    width: 100%; padding: 0.5rem 0.75rem 0.5rem 2.1rem;
    border: 1px solid var(--gray-border); border-radius: var(--radius-md);
    font-size: 0.875rem; font-family: var(--font); color: var(--black);
    background: var(--gray-bg); outline: none; transition: border-color 0.15s;
}
.jobs-filters__search-input:focus { border-color: var(--green-mid); }
.jobs-filters__select {
    padding: 0.5rem 0.75rem; border: 1px solid var(--gray-border);
    border-radius: var(--radius-md); font-size: 0.875rem; font-family: var(--font);
    color: var(--black); background: var(--gray-bg); outline: none; cursor: pointer;
}
.jobs-filters__remote {
    display: flex; align-items: center; gap: 6px;
    font-size: 0.875rem; color: var(--gray-text); cursor: pointer; white-space: nowrap;
}
.jobs-filters__remote input { accent-color: var(--green-mid); width: 16px; height: 16px; }
.jobs-filters__reset { font-size: 0.82rem; color: var(--gray-mid); text-decoration: underline; white-space: nowrap; }
.jobs-filters__reset:hover { color: var(--danger); }

/* ── Bandeau mes annonces ─────────────────────────────────────── */
.my-trades-banner {
    background: var(--white);
    border: 1px solid var(--gray-border);
    border-radius: var(--radius-lg);
    padding: 0.85rem 1.1rem;
}
.my-trades-banner__header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 0.65rem;
}
.my-trades-banner__title { font-size: 0.875rem; font-weight: 600; color: var(--gray-text); }
.my-trades-banner__list  { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.my-trades-banner__item  {
    display: flex; align-items: center; gap: 0.5rem;
    background: var(--gray-bg); border: 1px solid var(--gray-border);
    border-radius: var(--radius-md); padding: 0.4rem 0.75rem;
    font-size: 0.82rem; color: var(--black); transition: border-color 0.15s;
}
.my-trades-banner__item:hover { border-color: var(--green-mid); }
.my-trades-banner__item-title {
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 200px;
}
.my-trades-banner__actions { display: flex; gap: 0.5rem; flex-shrink: 0; margin-left: 0.35rem; }

.jobs-list__count { font-size: 0.82rem; color: var(--gray-mid); margin-bottom: 0.5rem; }

/* ── Carte annonce ────────────────────────────────────────────── */
.job-card {
    display: flex; flex-direction: column; gap: 0.5rem;
    background: var(--white); border: 1px solid var(--gray-border);
    border-radius: var(--radius-lg); padding: 1.1rem 1.25rem;
    text-decoration: none; color: var(--black);
    transition: box-shadow 0.15s, border-color 0.15s;
    margin-bottom: 0.65rem;
}
.job-card:hover { box-shadow: var(--shadow-sm); border-color: var(--green-border); text-decoration: none; }

.job-card__header { display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }

.job-card__type-badge {
    font-size: 11px; font-weight: 700; padding: 3px 9px; border-radius: 20px;
}
.job-card__type--offre  { background: #E1F5EE; color: #0F6E56; }
.job-card__type--recherche { background: #E6F1FB; color: #0C447C; }

.job-card__remote {
    font-size: 11px; font-weight: 600; padding: 3px 8px; border-radius: 20px;
    background: #FAEEDA; color: #633806;
}
.job-card__title { font-size: 1rem; font-weight: 600; color: var(--black); margin: 0; }
.job-card__company {
    display: flex; align-items: center; gap: 5px;
    font-size: 0.85rem; color: var(--gray-text);
}
.job-card__desc { font-size: 0.875rem; color: var(--gray-mid); line-height: 1.55; }
.job-card__footer {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 0.5rem; margin-top: 0.25rem;
    padding-top: 0.65rem; border-top: 1px solid var(--gray-light);
}
.job-card__meta { display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap; }
.job-card__meta-item {
    display: flex; align-items: center; gap: 4px;
    font-size: 0.78rem; color: var(--gray-mid);
}
.job-card__author { display: flex; align-items: center; gap: 6px; font-size: 0.78rem; color: var(--gray-mid); }
.job-card__avatar { border-radius: 50%; object-fit: cover; }
.job-card__time   { color: var(--gray-mid); }



/* Status badges */
.status-badge { font-size: 10px; font-weight: 700; padding: 2px 7px; border-radius: 20px; white-space: nowrap; }
.status-badge--pending   { background: #FAEEDA; color: #633806; }
.status-badge--published { background: #E1F5EE; color: #0F6E56; }
.status-badge--rejected  { background: #FCEBEB; color: #7a1f1f; }

/* Small links */
.link-sm { font-size: 0.78rem; color: var(--green-mid); text-decoration: underline; cursor: pointer; background: none; border: none; padding: 0; font-family: var(--font); }
.link-sm--danger { color: var(--danger); }

/* ── Pagination ───────────────────────────────────────────────── */
.pagination { display: flex; gap: 0.4rem; justify-content: center; margin-top: 1rem; flex-wrap: wrap; }
.pagination__btn {
    width: 34px; height: 34px; border-radius: var(--radius-sm);
    display: flex; align-items: center; justify-content: center;
    font-size: 0.875rem; color: var(--gray-text);
    border: 1px solid var(--gray-border); background: var(--white); text-decoration: none;
    transition: all 0.15s;
}
.pagination__btn:hover { border-color: var(--green-mid); color: var(--green-mid); text-decoration: none; }
.pagination__btn--active { background: var(--green-dark); color: #fff; border-color: var(--green-dark); }

/* ── Détail annonce ───────────────────────────────────────────── */
.job-detail { display: flex; flex-direction: column; gap: 1rem; }

.job-detail__layout {
    display: grid; grid-template-columns: 1fr 280px;
    gap: 1.1rem; align-items: start;
}
.job-detail__card {
    background: var(--white); border: 1px solid var(--gray-border);
    border-radius: var(--radius-lg); padding: 1.5rem;
    display: flex; flex-direction: column; gap: 1rem;
}
.job-detail__badges { display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }
.job-detail__title  { font-size: 1.4rem; font-weight: 700; margin: 0; }
.job-detail__company { display: flex; align-items: center; gap: 6px; font-size: 0.95rem; color: var(--gray-text); }

.job-detail__quick { display: flex; flex-direction: column; gap: 0.5rem; padding: 1rem; background: var(--gray-bg); border-radius: var(--radius-md); }
.job-detail__quick-item { display: flex; align-items: center; gap: 8px; font-size: 0.875rem; color: var(--gray-text); }

.job-detail__description { font-size: 0.95rem; line-height: 1.75; color: var(--black); white-space: pre-line; }

.job-detail__attachment {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 0.875rem; color: var(--green-mid);
    border: 1px solid var(--green-border); border-radius: var(--radius-md);
    padding: 0.5rem 0.85rem; text-decoration: none; width: fit-content;
    transition: background 0.15s;
}
.job-detail__attachment:hover { background: var(--green-light); text-decoration: none; }

.job-detail__author-card {
    background: var(--white); border: 1px solid var(--gray-border);
    border-radius: var(--radius-lg); padding: 1.25rem;
    position: sticky; top: calc(var(--topbar-h) + 1rem);
}
.job-detail__author { display: flex; align-items: center; gap: 0.75rem; text-decoration: none; }
.job-detail__author:hover .job-detail__author-name { text-decoration: underline; }
.job-detail__author-avatar { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.job-detail__author-name  { font-size: 0.95rem; font-weight: 600; color: var(--black); }
.job-detail__author-since { font-size: 0.78rem; color: var(--gray-mid); }

.job-detail__similar { margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--gray-light); }
.job-detail__similar-title { font-size: 0.85rem; font-weight: 600; margin-bottom: 0.65rem; }
.job-similar-item { display: flex; flex-direction: column; gap: 2px; padding: 0.5rem 0; border-bottom: 1px solid var(--gray-light); text-decoration: none; }
.job-similar-item:last-child { border-bottom: none; }
.job-similar-item__title { font-size: 0.82rem; color: var(--black); font-weight: 500; }
.job-similar-item:hover .job-similar-item__title { text-decoration: underline; }
.job-similar-item__time  { font-size: 0.72rem; color: var(--gray-mid); }

/* ── Formulaire ───────────────────────────────────────────────── */
.job-form-page { display: flex; flex-direction: column; gap: 1rem; }
.job-form-header { display: flex; align-items: center; gap: 1rem; }
.job-form-header__title { font-size: 1.2rem; font-weight: 600; margin: 0; }
.job-form { display: flex; flex-direction: column; gap: 1rem; }

.job-form__card {
    background: var(--white); border: 1px solid var(--gray-border);
    border-radius: var(--radius-lg); padding: 1.5rem;
    display: flex; flex-direction: column; gap: 1rem;
}
.job-form__section-title {
    display: flex; align-items: center; gap: 0.65rem;
    font-size: 0.95rem; font-weight: 600;
    padding-bottom: 0.75rem; border-bottom: 1px solid var(--gray-light);
    margin-bottom: 0.25rem;
}
.job-form__step {
    width: 24px; height: 24px; border-radius: 50%;
    background: var(--green-dark); color: #fff;
    font-size: 12px; font-weight: 700; display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}

/* Grille sélection type */
.job-type-grid {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.65rem;
}
.job-type-card {
    display: flex; flex-direction: column; align-items: center;
    gap: 0.5rem; padding: 1rem 0.75rem;
    border: 1.5px solid var(--gray-border); border-radius: var(--radius-md);
    cursor: pointer; text-align: center; font-size: 0.85rem; color: var(--gray-text);
    transition: border-color 0.15s, background 0.15s;
    background: var(--white);
}
.job-type-card input { display: none; }
.job-type-card:hover { border-color: var(--green-mid); background: var(--green-light); color: #0F6E56; }
.job-type-card--selected { border-color: var(--green-dark); background: var(--green-light); color: #0F6E56; font-weight: 600; }

.job-form__footer {
    display: flex; justify-content: flex-end; gap: 0.75rem; flex-wrap: wrap;
    padding-top: 0.5rem;
}

/* Alertes info */
.alert--info { background: var(--blue-light); color: var(--blue-text); border: 1px solid #B5D4F4; }
.alert--warning { background: #FAEEDA; color: #633806; border: 1px solid #FAC775; }
.alert__link { color: inherit; font-weight: 600; margin-left: 0.5rem; }

/* ── Responsive ───────────────────────────────────────────────── */
@media (max-width: 768px) {
    .job-detail__layout  { grid-template-columns: 1fr; }
    .job-detail__author-card { position: static; }
    .job-type-grid       { grid-template-columns: 1fr 1fr; }
    .jobs-filters        { flex-direction: column; align-items: stretch; }
    .jobs-filters__search { min-width: 0; }
    .my-trades-banner__item-title { max-width: 140px; }
}
@media (max-width: 480px) {
    .job-type-grid { grid-template-columns: 1fr; }
}
