/* ============================================================
   PPC Recrutement — Design
   Thème : Professionnel · Violet confiance · Propre
   ============================================================ */
:root {
  --fond:      #06070F;
  --surface:   #0C0D1A;
  --surface2:  #131427;
  --surface3:  #1B1D35;
  --texte:     #F0EFF8;
  --dim:       #9090B8;
  --mute:      #484870;
  --violet:    #6366F1;
  --violet2:   #818CF8;
  --violet-glow: rgba(99,102,241,0.25);
  --vert:      #10B981;
  --rouge:     #EF4444;
  --or:        #F59E0B;
  --bordure:   rgba(99,102,241,0.12);
  --bordure2:  rgba(99,102,241,0.22);
  --grad:      linear-gradient(135deg, #6366F1, #8B5CF6);
  --radius:    14px;
  --radius-sm: 8px;
  --radius-lg: 20px;
  --shadow:    0 4px 32px rgba(0,0,0,0.5);
  --glow:      0 0 40px rgba(99,102,241,0.18);
}
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:15px; scroll-behavior:smooth; }
body { font-family:'Inter',system-ui,sans-serif; background:var(--fond); color:var(--texte); min-height:100vh; -webkit-font-smoothing:antialiased; }
a { color:var(--violet2); text-decoration:none; transition:color .2s; }
a:hover { color:var(--violet); }
img { display:block; max-width:100%; }

/* ── HEADER ─────────────────────────────────────────────────── */
.header { position:sticky; top:0; z-index:100; background:rgba(6,7,15,0.92); backdrop-filter:blur(14px); border-bottom:1px solid var(--bordure); }
.header__inner { max-width:1100px; margin:0 auto; padding:0 24px; height:64px; display:flex; align-items:center; gap:16px; }
.header__logo { display:flex; align-items:center; gap:10px; text-decoration:none; }
.header__logo-icon { width:36px; height:36px; background:var(--grad); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; }
.header__logo-text { font-size:1.05rem; font-weight:800; color:var(--texte); }
.header__logo-sub  { font-size:.65rem; color:var(--dim); font-weight:500; }
.header__nav { display:flex; gap:4px; margin-left:auto; }
.header__nav a { padding:7px 14px; border-radius:var(--radius-sm); font-size:.82rem; font-weight:500; color:var(--dim); transition:all .15s; }
.header__nav a:hover { background:var(--surface2); color:var(--texte); }
.header__cta { background:var(--grad); color:#fff !important; font-weight:700 !important; box-shadow:0 2px 14px var(--violet-glow); }
.header__cta:hover { opacity:.9; }

/* ── HERO ────────────────────────────────────────────────────── */
.hero { padding:90px 24px 70px; text-align:center; position:relative; overflow:hidden; }
.hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% -10%, rgba(99,102,241,.2), transparent 65%); pointer-events:none; }
.hero__eyebrow { display:inline-flex; align-items:center; gap:8px; background:rgba(99,102,241,.1); border:1px solid var(--bordure2); color:var(--violet2); padding:6px 16px; border-radius:20px; font-size:.75rem; font-weight:700; letter-spacing:.05em; margin-bottom:22px; }
.hero__title { font-size:clamp(2rem,6vw,3.6rem); font-weight:900; letter-spacing:-.04em; line-height:1.1; margin-bottom:18px; }
.hero__title em { font-style:normal; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero__sub { color:var(--dim); font-size:1.05rem; max-width:560px; margin:0 auto 32px; line-height:1.7; }
.hero__actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.hero__stats { display:flex; gap:32px; justify-content:center; margin-top:48px; flex-wrap:wrap; }
.hero__stat { text-align:center; }
.hero__stat-val { font-size:1.8rem; font-weight:900; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero__stat-lbl { font-size:.75rem; color:var(--dim); margin-top:3px; }

/* ── CONTAINER ───────────────────────────────────────────────── */
.container { max-width:1100px; margin:0 auto; padding:0 24px; }
.section { padding:56px 0; }
.section__header { text-align:center; margin-bottom:40px; }
.section__eyebrow { font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--violet2); margin-bottom:10px; }
.section__title { font-size:clamp(1.5rem,4vw,2.2rem); font-weight:900; letter-spacing:-.02em; margin-bottom:12px; }
.section__sub { color:var(--dim); font-size:.95rem; max-width:520px; margin:0 auto; line-height:1.65; }

/* ── FILTRES ─────────────────────────────────────────────────── */
.filters { display:flex; gap:8px; flex-wrap:wrap; justify-content:center; margin-bottom:36px; }
.filter-btn { display:inline-flex; align-items:center; gap:6px; padding:8px 16px; border-radius:20px; font-size:.82rem; font-weight:600; border:1.5px solid var(--bordure); background:var(--surface); color:var(--dim); cursor:pointer; text-decoration:none; transition:all .15s; }
.filter-btn:hover { border-color:var(--violet); color:var(--violet2); }
.filter-btn.active { background:rgba(99,102,241,.12); border-color:var(--violet); color:var(--violet2); }

/* ── OFFRE CARD ──────────────────────────────────────────────── */
.offres-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(340px,1fr)); gap:18px; }
.offre-card { background:var(--surface); border:1px solid var(--bordure); border-radius:var(--radius-lg); padding:24px; display:flex; flex-direction:column; gap:14px; transition:border-color .2s,box-shadow .2s,transform .2s; position:relative; overflow:hidden; }
.offre-card::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 0% 0%, rgba(99,102,241,.06), transparent 60%); pointer-events:none; opacity:0; transition:opacity .3s; }
.offre-card:hover { border-color:var(--bordure2); box-shadow:var(--glow); transform:translateY(-2px); }
.offre-card:hover::before { opacity:1; }
.offre-card__urgent { position:absolute; top:16px; right:16px; background:rgba(239,68,68,.15); color:#FCA5A5; border:1px solid rgba(239,68,68,.3); padding:3px 10px; border-radius:20px; font-size:.65rem; font-weight:800; letter-spacing:.05em; text-transform:uppercase; animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1}50%{opacity:.7} }
.offre-card__header { display:flex; align-items:flex-start; gap:14px; }
.offre-card__icon { width:48px; height:48px; border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center; font-size:1.4rem; flex-shrink:0; }
.offre-card__meta { flex:1; min-width:0; }
.offre-card__titre { font-size:1rem; font-weight:800; margin-bottom:5px; }
.offre-card__badges { display:flex; gap:6px; flex-wrap:wrap; }
.badge { display:inline-flex; align-items:center; gap:4px; padding:3px 9px; border-radius:20px; font-size:.68rem; font-weight:700; }
.badge--poste   { background:rgba(99,102,241,.1); }
.badge--contrat { background:rgba(16,185,129,.1); color:#34D399; }
.badge--urgent  { background:rgba(239,68,68,.1); color:#FCA5A5; }
.offre-card__desc { font-size:.85rem; color:var(--dim); line-height:1.65; flex:1; }
.offre-card__footer { display:flex; align-items:center; justify-content:space-between; gap:10px; padding-top:12px; border-top:1px solid var(--bordure); }
.offre-card__info { font-size:.75rem; color:var(--mute); display:flex; gap:12px; flex-wrap:wrap; }
.offre-card__info span { display:flex; align-items:center; gap:4px; }

/* ── OFFRE DÉTAIL ────────────────────────────────────────────── */
.offre-detail { max-width:780px; margin:0 auto; }
.offre-detail__header { background:var(--surface); border:1px solid var(--bordure); border-radius:var(--radius-lg); padding:32px; margin-bottom:20px; }
.offre-detail__body   { display:grid; grid-template-columns:1fr 300px; gap:20px; align-items:start; }
.offre-detail__content { display:flex; flex-direction:column; gap:20px; }
.offre-detail__sidebar { display:flex; flex-direction:column; gap:14px; }
.offre-detail__section { background:var(--surface); border:1px solid var(--bordure); border-radius:var(--radius); padding:20px; }
.offre-detail__section h3 { font-size:.72rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--mute); margin-bottom:14px; }
.offre-detail__section ul { list-style:none; display:flex; flex-direction:column; gap:8px; }
.offre-detail__section li { display:flex; gap:8px; align-items:flex-start; font-size:.875rem; color:var(--dim); line-height:1.5; }
.offre-detail__section li::before { content:'→'; color:var(--violet2); font-weight:700; flex-shrink:0; margin-top:1px; }

/* ── FORMULAIRE CANDIDATURE ──────────────────────────────────── */
.candidature-form { background:var(--surface); border:1px solid var(--bordure); border-radius:var(--radius-lg); padding:28px; }
.form-section { margin-bottom:24px; padding-bottom:24px; border-bottom:1px solid var(--bordure); }
.form-section:last-of-type { border-bottom:none; margin-bottom:0; }
.form-section__title { font-size:.72rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--violet2); margin-bottom:16px; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-label { font-size:.8rem; font-weight:600; color:var(--dim); }
.form-label .req { color:var(--rouge); margin-left:2px; }
.form-input, .form-select, .form-textarea {
  padding:11px 14px; background:var(--surface2); border:1.5px solid rgba(99,102,241,.15);
  border-radius:var(--radius-sm); color:var(--texte); font-family:inherit; font-size:.875rem;
  outline:none; transition:border-color .2s,box-shadow .2s; width:100%; -webkit-appearance:none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color:var(--violet); box-shadow:0 0 0 3px rgba(99,102,241,.12);
}
.form-input::placeholder, .form-textarea::placeholder { color:var(--mute); }
.form-textarea { resize:vertical; min-height:100px; line-height:1.6; }
.form-hint { font-size:.72rem; color:var(--mute); }

/* ── BOUTONS ─────────────────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:12px 24px; border-radius:var(--radius-sm); font-size:.9rem; font-weight:700; border:none; cursor:pointer; text-decoration:none; transition:all .18s; font-family:inherit; white-space:nowrap; }
.btn--primary { background:var(--grad); color:#fff; box-shadow:0 4px 20px var(--violet-glow); }
.btn--primary:hover { opacity:.9; transform:translateY(-1px); }
.btn--ghost { background:var(--surface2); border:1.5px solid var(--bordure2); color:var(--texte); }
.btn--ghost:hover { border-color:var(--violet); color:var(--violet2); }
.btn--lg { padding:14px 32px; font-size:1rem; }
.btn--full { width:100%; }
.btn--sm { padding:8px 16px; font-size:.8rem; }

/* ── SUCCÈS ──────────────────────────────────────────────────── */
.merci-card { max-width:540px; margin:80px auto; background:var(--surface); border:1px solid var(--bordure); border-radius:var(--radius-lg); padding:48px; text-align:center; }
.merci-card__icon { font-size:4rem; margin-bottom:20px; }
.merci-card h1 { font-size:1.8rem; font-weight:900; margin-bottom:12px; }
.merci-card p { color:var(--dim); line-height:1.7; }

/* ── VALEURS ─────────────────────────────────────────────────── */
.valeurs-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:14px; }
.valeur-card { background:var(--surface); border:1px solid var(--bordure); border-radius:var(--radius); padding:22px; }
.valeur-card__icon { font-size:2rem; margin-bottom:12px; }
.valeur-card h3 { font-size:.95rem; font-weight:700; margin-bottom:6px; }
.valeur-card p  { font-size:.82rem; color:var(--dim); line-height:1.6; }

/* ── PROCESSUS ───────────────────────────────────────────────── */
.process-steps { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:0; position:relative; }
.process-steps::before { content:''; position:absolute; top:28px; left:10%; right:10%; height:1px; background:var(--bordure); }
.process-step { text-align:center; padding:0 10px; position:relative; }
.process-step__num { width:56px; height:56px; border-radius:50%; background:var(--surface); border:2px solid var(--violet); display:flex; align-items:center; justify-content:center; font-size:1.2rem; font-weight:900; color:var(--violet2); margin:0 auto 14px; position:relative; z-index:1; background:var(--fond); }
.process-step h4 { font-size:.875rem; font-weight:700; margin-bottom:5px; }
.process-step p  { font-size:.78rem; color:var(--dim); line-height:1.5; }

/* ── FOOTER ──────────────────────────────────────────────────── */
.footer { border-top:1px solid var(--bordure); padding:32px 24px; text-align:center; color:var(--mute); font-size:.78rem; }
.footer a { color:var(--dim); }

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media (max-width:900px) {
  .offre-detail__body { grid-template-columns:1fr; }
  .offres-grid { grid-template-columns:1fr; }
  .header__nav a:not(.header__cta) { display:none; }
  .hero { padding:60px 20px 48px; }
  .process-steps::before { display:none; }
}
@media (max-width:600px) {
  .form-grid { grid-template-columns:1fr; }
  .hero__stats { gap:20px; }
  .hero__actions { flex-direction:column; align-items:center; }
}
