/* =========================
   Variables globales thème
   ========================= */
:root{
  --gsjb-primary:#FF8C00;
  --gsjb-primary-600:#e67d00;
  --gsjb-text:#111827;
  --gsjb-muted:#6b7280;
  --gsjb-border:#e5e7eb;
  --gsjb-bg:#ffffff;
  --gsjb-chip:#f3f4f6;
  --gsjb-banner:#FFE9D2; /* bannière derrière le menu */
  --gsjb-content-max:1000px;

  /* layout single */
  --gsjb-banner-h:140px;
  --gsjb-gap-top:96px;
}

/* =========================
   Bannière derrière le menu
   ========================= */
body.single-gsjb_job{
  position:relative;
}
body.single-gsjb_job::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:var(--gsjb-banner-h);
  background:var(--gsjb-banner);
  z-index:0;
}

/* Header sticky + transparent au-dessus de la bannière */
body.single-gsjb_job .site-header,
body.single-gsjb_job .main-header-bar,
body.single-gsjb_job .ast-primary-header-bar{
  position:sticky;
  top:0;
  z-index:1000;
  background:transparent !important;
  box-shadow:none;
  border-bottom:0;
}

/* Le contenu du site démarre sous la bannière */
body.single-gsjb_job .site-content{
  position:relative;
  z-index:1;
  padding-top:var(--gsjb-gap-top);
}

/* =========================
   Wrapper global du board
   ========================= */
.gsjb-wrap{
  max-width:var(--gsjb-content-max);
  margin:40px auto;
  padding:0 16px;
  font-family:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
}

/* =========================
   BARRE DE FILTRES RESPONSIVE
   ========================= */
/* Conteneur global des filtres */
.gsjb-filters{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-start;
  gap:12px;
  background:var(--gsjb-bg);
  border:1px solid var(--gsjb-border);
  border-radius:18px;
  padding:12px;
  box-shadow:0 2px 8px rgba(0,0,0,.04);
  max-width:var(--gsjb-content-max);
  margin:0 auto;
}

/* Champs (inputs / selects) */
.gsjb-filters input,
.gsjb-filters select{
  border:1px solid var(--gsjb-border);
  border-radius:12px;
  padding:10px 12px;
  font-size:14px;
  color:var(--gsjb-text);
  background-color:#fff;
  width:100%;
  box-sizing:border-box;
  font-family:inherit;
  line-height:1.3;
}

/* Boutons */
.gsjb-btn{
  background:var(--gsjb-primary);
  color:#fff;
  border:none;
  border-radius:16px;
  padding:10px 14px;
  font-weight:700;
  font-size:14px;
  cursor:pointer;
  transition:background .15s ease,transform .05s ease;
  width:100%;
  text-align:center;
  line-height:1.3;
}
.gsjb-btn:hover{
  background:var(--gsjb-primary-600);
}
.gsjb-btn:active{
  transform:scale(.99);
}
.gsjb-btn.ghost{
  background:#fff;
  color:var(--gsjb-text);
  border:1px solid var(--gsjb-border);
}

/* Télétravail : wrapper du checkbox + texte */
.gsjb-checkbox{
  display:flex;
  align-items:center;
  gap:8px;
  color:var(--gsjb-text);
  font-size:14px;
  line-height:1.3;
  font-weight:500;
}

/* On s'assure que la checkbox native s'aligne bien verticalement */
.gsjb-checkbox input[type="checkbox"]{
  width:auto;
  height:auto;
  margin:0;
  flex-shrink:0;
}

/* ===== Layout mobile par défaut ===== */
.gsjb-filters input[type="search"],
.gsjb-filters input[type="text"],
.gsjb-filters select{
  flex:1 1 100%;
  min-width:0;
}

.gsjb-checkbox{
  flex:1 1 100%;
  min-width:0;
}

.gsjb-filters .gsjb-btn{
  flex:1 1 100%;
  min-width:0;
}

/* ===== Tablet / desktop >=768px ===== */
@media(min-width:768px){

  /* On garde flex-wrap:wrap.
     Chaque champ prend max ~220px pour éviter la fuite hors cadre.
     Et si ça ne tient pas en une ligne ? Retour à la ligne propre.
  */
  .gsjb-filters{
    row-gap:12px;
    column-gap:12px;
  }

  .gsjb-filters input[type="search"],
  .gsjb-filters input[type="text"],
  .gsjb-filters select{
    flex:0 1 220px;
    max-width:220px;
  }

  /* Télétravail devient un petit bloc compact */
  .gsjb-checkbox{
    flex:0 0 auto;
    width:auto;
    white-space:nowrap;
    order:10;
  }

  /* Bouton Rechercher */
  .gsjb-filters .gsjb-btn{
    flex:0 0 auto;
    width:auto;
    min-width:140px;
    order:20;
  }

  /* Bouton ghost (Réinitialiser) reste à côté */
  .gsjb-filters .gsjb-btn.ghost{
    background:#fff;
    color:var(--gsjb-text);
    border:1px solid var(--gsjb-border);
  }
}

/* ===== Desktop large >=1024px ===== */
@media(min-width:1024px){

  .gsjb-filters{
    row-gap:12px;
    column-gap:12px;
  }

  .gsjb-filters input[type="search"],
  .gsjb-filters input[type="text"],
  .gsjb-filters select{
    flex:0 1 200px;
    max-width:200px;
  }

  .gsjb-checkbox{
    flex:0 0 auto;
  }
}

/* =========================
   LISTE D'OFFRES (cards)
   ========================= */
.gsjb-grid{
  max-width:var(--gsjb-content-max);
  margin:18px auto 0;
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}

@media(min-width:720px){
  .gsjb-grid{
    grid-template-columns:1fr 1fr;
  }
}

.gsjb-card{
  border:1px solid var(--gsjb-border);
  border-radius:18px;
  padding:18px;
  background:#fff;
  box-shadow:0 2px 8px rgba(0,0,0,.04);
  transition:transform .06s ease, box-shadow .12s ease;
}
.gsjb-card:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(0,0,0,.06);
}

.gsjb-title{
  font-size:18px;
  font-weight:800;
  color:var(--gsjb-text);
  text-decoration:none;
  line-height:1.3;
}
.gsjb-title:hover{
  color:var(--gsjb-primary);
}

.gsjb-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:8px 0 10px;
  color:var(--gsjb-muted);
  font-size:13px;
  line-height:1.4;
}
.gsjb-badge{
  background:var(--gsjb-chip);
  color:var(--gsjb-text);
  border-radius:999px;
  padding:4px 10px;
  font-size:12px;
  font-weight:700;
  line-height:1.3;
}

.gsjb-excerpt{
  color:#374151;
  font-size:14px;
  line-height:1.5;
  margin:0;
}

.gsjb-foot{
  margin-top:12px;
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  flex-wrap:wrap;
  row-gap:12px;
}
.gsjb-salary{
  font-weight:800;
  color:var(--gsjb-text);
  font-size:14px;
  line-height:1.4;
}
.gsjb-btn.small{
  padding:10px 14px;
  border-radius:14px;
  font-size:14px;
  line-height:1.3;
}

/* Pagination */
.gsjb-pagination{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:center;
  margin:18px 0;
  font-size:14px;
  line-height:1.3;
}
.gsjb-pagination a{
  border:1px solid var(--gsjb-border);
  border-radius:10px;
  padding:6px 10px;
  text-decoration:none;
  color:var(--gsjb-text);
}
.gsjb-pagination a.active{
  background:var(--gsjb-primary);
  color:#fff;
  border-color:var(--gsjb-primary);
}

/* =========================
   HERO DE L'OFFRE
   ========================= */
.gsjb-offer-hero{
  background:linear-gradient(180deg, rgba(255,140,0,0.08), transparent 70%);
  padding-top:18px;
  padding-bottom:8px;
  margin:0 0 8px 0;
}
.gsjb-hero-inner{
  max-width:var(--gsjb-content-max);
  margin:0 auto;
  padding:0 16px;
}
.gsjb-hero-title{
  margin:0 0 8px 0;
  font-size:30px;
  line-height:1.15;
  font-weight:800;
  color:#111827;
}
.gsjb-hero-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  color:var(--gsjb-muted);
  font-size:13px;
  line-height:1.4;
}

/* Les puces info (lieu / contrat / expérience...) */
.gsjb-hero-meta span{
  background:#F5F6F7;
  border-radius:999px;
  padding:6px 12px 6px 30px;
  font-size:13px;
  font-weight:700;
  color:#111827;
  position:relative;
  display:inline-flex;
  align-items:center;
  line-height:1.3;
}

/* Icônes intégrées par CSS */
.gsjb-hero-meta span:nth-child(1)::before,
.gsjb-hero-meta span:nth-child(2)::before,
.gsjb-hero-meta span:nth-child(3)::before{
  content:"";
  position:absolute;
  left:10px;
  width:14px;
  height:14px;
  background-size:14px 14px;
  background-repeat:no-repeat;
  filter:grayscale(0.1);
  opacity:.9;
}
/* Lieu */
.gsjb-hero-meta span:nth-child(1)::before{
  background-image:url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 24 24' fill='%23111827' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 2C8.134 2 5 5.134 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.866-3.134-7-7-7Zm0 9.5a2.5 2.5 0 1 1 0-5 2.5 2.5 0 0 1 0 5Z'/%3E%3C/svg%3E");
}
/* Contrat */
.gsjb-hero-meta span:nth-child(2)::before{
  background-image:url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 24 24' fill='%23111827' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M7 3h10a2 2 0 0 1 2 2v11.5L14 21l-5-4.5V5a2 2 0 0 1 2-2Z'/%3E%3C/svg%3E");
}
/* Expérience */
.gsjb-hero-meta span:nth-child(3)::before{
  background-image:url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 24 24' fill='%23111827' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9 2h6v2H9zM12 6a8 8 0 1 0 .001 16.001A8 8 0 0 0 12 6Zm1 4h-2v5l4 2 .9-1.8-2.9-1.45z'/%3E%3C/svg%3E");
}

/* =========================
   CONTENU DE L'OFFRE
   ========================= */

/* Grille : texte + encart Postuler sticky à droite */
.single-gsjb_job .entry-content{
  max-width:var(--gsjb-content-max);
  margin:0 auto;
  padding:0 16px;
  display:grid;
  grid-template-columns:1fr;
  gap:28px;
}
@media(min-width:992px){
  .single-gsjb_job .entry-content{
    grid-template-columns:minmax(0,1fr) 360px;
    align-items:start;
  }
  .single-gsjb_job .entry-content .gsjb-apply{
    position:sticky;
    top:96px;
  }
}

/* Typo texte offre */
.single-gsjb_job .entry-content p{
  line-height:1.7;
  font-size:16px;
  color:#1f2937;
  margin:0 0 1em 0;
}
.single-gsjb_job .entry-content h2,
.single-gsjb_job .entry-content h3{
  font-weight:700;
  color:#111827;
  margin-top:1.2em;
  margin-bottom:.6em;
  line-height:1.3;
}
.single-gsjb_job .entry-content ul{
  margin:0 0 1em 1.2em;
  padding:0;
  line-height:1.6;
  color:#1f2937;
}
.single-gsjb_job .entry-content ul li{
  margin-bottom:.4em;
  font-size:16px;
}

/* Séparateur avant la section Postuler */
.gsjb-divider{
  width:80px;
  height:4px;
  background-color:var(--gsjb-primary);
  border-radius:3px;
  margin:40px 0 24px;
}

/* =========================
   FORMULAIRE POSTULER
   ========================= */
.gsjb-apply{
  border:1px solid var(--gsjb-border);
  border-radius:16px;
  background:#fff;
  box-shadow:0 4px 16px rgba(0,0,0,.05);
  padding:24px;
}
.gsjb-apply h2{
  margin-top:0;
  font-size:18px;
  font-weight:800;
  line-height:1.3;
  color:#111827;
}
.gsjb-apply-note{
  color:#6b7280;
  margin-top:0;
  margin-bottom:16px;
  font-size:14px;
  line-height:1.4;
}
.gsjb-apply-form{
  margin-top:12px;
}

/* Harmonisation Forminator */
.forminator-ui .forminator-button{
  background:var(--gsjb-primary) !important;
  border:none !important;
  font-weight:700 !important;
  border-radius:12px !important;
  padding:10px 16px !important;
  font-size:15px !important;
  line-height:1.3 !important;
  box-shadow:none !important;
}
.forminator-ui .forminator-button:hover{
  filter:brightness(.95);
}

.forminator-ui .forminator-input,
.forminator-ui .forminator-textarea,
.forminator-ui .forminator-select{
  border-radius:12px !important;
  border:1px solid var(--gsjb-border) !important;
  padding:10px 12px !important;
  line-height:1.4 !important;
  font-size:15px !important;
  box-shadow:none !important;
}
.forminator-ui .forminator-label{
  font-weight:700 !important;
  color:#374151 !important;
  font-size:14px !important;
  line-height:1.4 !important;
}
.forminator-ui .forminator-error-message{
  font-size:13px !important;
  line-height:1.4 !important;
}
