/* ============================================================
   NEAR-JOB - components.css  (composants réutilisables)
   ============================================================ */

/* ── Search Bar ──────────────────────────────────────────── */
.search-bar-wrap { background: #fff; border-radius: var(--radius-lg); box-shadow: var(--shadow-md);
  padding: .5rem; display: flex; flex-wrap: wrap; gap: .5rem; }
.search-field { flex: 1 1 200px; position: relative; }
.search-field input {
  width: 100%; height: 48px; padding: 0 1rem 0 2.75rem;
  border: 1.5px solid var(--clr-border); border-radius: var(--radius-md);
  font-size: .9rem; color: var(--clr-text); background: var(--clr-bg);
  outline: none; transition: border-color .15s;
}
.search-field input:focus { border-color: var(--clr-primary); background: #fff; }
.search-field .field-icon {
  position: absolute; left: .85rem; top: 50%; transform: translateY(-50%);
  color: var(--clr-subtle); pointer-events: none; font-size: 1rem;
}
.search-btn { height: 48px; padding: 0 1.5rem; border-radius: var(--radius-md);
  background: var(--clr-primary); color: #fff; font-weight: 700; font-size: .95rem;
  border: none; cursor: pointer; transition: background .15s; flex-shrink: 0; }
.search-btn:hover { background: var(--clr-primary-d); }

/* Autocomplete dropdown */
.autocomplete-dropdown {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 200;
  background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius-md);
  box-shadow: var(--shadow-md); overflow: hidden; max-height: 280px; overflow-y: auto;
}
.autocomplete-item {
  padding: .65rem 1rem; cursor: pointer; font-size: .875rem; color: var(--clr-text);
  display: flex; align-items: center; gap: .6rem; transition: background .1s;
}
.autocomplete-item:hover, .autocomplete-item.active { background: var(--clr-primary-l); color: var(--clr-primary); }
.autocomplete-item .item-icon { color: var(--clr-subtle); font-size: .85rem; }

/* ── Provider Card ───────────────────────────────────────── */
.provider-card {
  background: var(--clr-surface); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm); border: 1px solid var(--clr-border);
  overflow: hidden; display: flex; flex-direction: column;
  transition: box-shadow .2s, transform .15s;
}
.provider-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.provider-card.is-featured { border-color: var(--clr-gold); }
.featured-ribbon {
  background: var(--clr-gold); color: #fff; font-size: .7rem; font-weight: 700;
  padding: .2rem .8rem; text-align: center; text-transform: uppercase; letter-spacing: .05em;
}
.card-body { padding: 1.25rem; flex: 1; display: flex; flex-direction: column; gap: .75rem; }
.card-header { display: flex; gap: 1rem; align-items: flex-start; }
.card-avatar { width: 60px; height: 60px; border-radius: 50%; object-fit: cover;
  flex-shrink: 0; border: 2px solid var(--clr-border); background: var(--clr-bg); }
.card-title { flex: 1; min-width: 0; }
.card-name { font-size: 1rem; font-weight: 700; color: var(--clr-text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.card-location { font-size: .8rem; color: var(--clr-muted); margin-top: .15rem; }
.card-headline { font-size: .875rem; color: var(--clr-muted); line-height: 1.5;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.card-meta { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; }
.card-skills { display: flex; flex-wrap: wrap; gap: .35rem; }
.skill-tag {
  background: var(--clr-bg); border: 1px solid var(--clr-border); border-radius: 99px;
  padding: .2rem .65rem; font-size: .75rem; color: var(--clr-muted);
}
.card-stats { display: flex; gap: 1rem; font-size: .8rem; color: var(--clr-muted); margin-top: auto; }
.card-stat { display: flex; align-items: center; gap: .25rem; }
.card-price { font-size: .95rem; font-weight: 700; color: var(--clr-text); }
.card-cta { padding: 1rem 1.25rem; border-top: 1px solid var(--clr-border);
  display: flex; gap: .5rem; align-items: center; }
.distance-chip { font-size: .75rem; color: var(--clr-primary); background: var(--clr-primary-l);
  padding: .2rem .6rem; border-radius: 99px; font-weight: 500; flex-shrink: 0; }
.card-cta .btn { flex: 1; }

/* ── Verification Badge ──────────────────────────────────── */
.badge-verified {
  display: inline-flex; align-items: center; gap: .3rem;
  font-size: .72rem; font-weight: 600; padding: .25rem .6rem;
  border-radius: 99px; letter-spacing: .02em;
}
.badge-verified svg { width: 12px; height: 12px; flex-shrink: 0; }
.badge-none     { background: #f1f5f9; color: var(--clr-subtle); }
.badge-identity { background: #dbeafe; color: #1d4ed8; }
.badge-activity { background: var(--clr-primary-l); color: var(--clr-primary); }
.badge-premium  { background: #fef3c7; color: #92400e; }

/* ── Rating Stars ────────────────────────────────────────── */
.rating { display: inline-flex; align-items: center; gap: .3rem; }
.rating-stars { display: inline-flex; gap: 1px; line-height: 1; }
.star       { font-size: .9rem; }
.star-full  { color: var(--clr-gold); }
.star-half  { color: var(--clr-gold); opacity: .6; }
.star-empty { color: var(--clr-border); }
.rating-count { font-size: .8rem; color: var(--clr-muted); }
.rating-value { font-size: .875rem; font-weight: 700; color: var(--clr-text); }

/* ── Filters Sidebar ─────────────────────────────────────── */
.search-page { padding: 1.5rem 0 3rem; }
.search-bar-compact { background: var(--clr-primary); padding: 1rem 0; }
.search-bar-compact .search-bar-wrap { background: rgba(255,255,255,.15);
  backdrop-filter: blur(8px); }
.search-bar-compact .search-field input { background: rgba(255,255,255,.9); }

.results-layout { display: grid; grid-template-columns: 1fr; gap: 1.5rem; margin-top: 1.5rem; }
@media (min-width: 900px) {
  .results-layout { grid-template-columns: 260px 1fr; align-items: start; }
}

.filters-sidebar { background: var(--clr-surface); border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg); overflow: hidden; }
.filters-header { padding: 1rem 1.25rem; border-bottom: 1px solid var(--clr-border);
  display: flex; justify-content: space-between; align-items: center; }
.filters-header h3 { font-size: .9rem; font-weight: 700; }
.filter-group { padding: 1rem 1.25rem; border-bottom: 1px solid var(--clr-border); }
.filter-group:last-child { border-bottom: none; }
.filter-group label { display: block; font-size: .8rem; font-weight: 600;
  color: var(--clr-muted); text-transform: uppercase; letter-spacing: .05em; margin-bottom: .6rem; }
.filter-select { width: 100%; padding: .45rem .75rem; border-radius: var(--radius-sm);
  border: 1px solid var(--clr-border); background: var(--clr-bg);
  color: var(--clr-text); font-size: .875rem; cursor: pointer; }
.filter-select:focus { outline: none; border-color: var(--clr-primary); }
.filter-radio-group { display: flex; flex-wrap: wrap; gap: .4rem; }
.filter-radio { position: relative; }
.filter-radio input { position: absolute; opacity: 0; width: 0; height: 0; }
.filter-radio span {
  display: block; padding: .3rem .7rem; border: 1.5px solid var(--clr-border);
  border-radius: 99px; font-size: .8rem; cursor: pointer; transition: all .15s; color: var(--clr-muted);
}
.filter-radio input:checked + span { background: var(--clr-primary); color: #fff; border-color: var(--clr-primary); }
.filter-range { width: 100%; margin-top: .5rem; accent-color: var(--clr-primary); }
.range-display { font-size: .875rem; font-weight: 600; color: var(--clr-text); margin-bottom: .25rem; }
.filter-toggle { display: flex; align-items: center; gap: .75rem; cursor: pointer; }
.filter-toggle input[type=checkbox] { width: 18px; height: 18px; accent-color: var(--clr-primary); cursor: pointer; }
.filter-toggle .toggle-label { font-size: .875rem; color: var(--clr-text); font-weight: 500; }

/* Mobile filters toggle */
.filters-toggle-btn { display: flex; align-items: center; gap: .5rem; margin-bottom: 1rem;
  background: var(--clr-surface); border: 1px solid var(--clr-border);
  border-radius: var(--radius-md); padding: .55rem 1rem; font-size: .875rem;
  font-weight: 600; cursor: pointer; }
@media (min-width: 900px) { .filters-toggle-btn { display: none; } }

/* ── Results Area ────────────────────────────────────────── */
.results-header { display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 1rem; flex-wrap: wrap; gap: .5rem; }
.results-count { font-size: .9rem; color: var(--clr-muted); }
.results-count strong { color: var(--clr-text); }
.results-sort { display: flex; align-items: center; gap: .5rem; }
.results-sort label { font-size: .8rem; color: var(--clr-muted); }
.sort-select { padding: .35rem .65rem; border: 1px solid var(--clr-border);
  border-radius: var(--radius-sm); font-size: .875rem; background: var(--clr-surface);
  cursor: pointer; }
.sort-select:focus { outline: none; border-color: var(--clr-primary); }

.results-grid { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 640px) {
  .results-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1100px) {
  .results-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ── Pagination ──────────────────────────────────────────── */
.pagination { display: flex; justify-content: center; align-items: center;
  gap: .5rem; margin-top: 2rem; flex-wrap: wrap; }
.pagination a, .pagination span {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: var(--radius-sm);
  font-size: .875rem; font-weight: 500; border: 1px solid var(--clr-border);
  background: var(--clr-surface); color: var(--clr-text); transition: all .15s;
}
.pagination a:hover { background: var(--clr-primary-l); border-color: var(--clr-primary); color: var(--clr-primary); }
.pagination .active { background: var(--clr-primary); color: #fff; border-color: var(--clr-primary); }
.pagination .disabled { opacity: .4; pointer-events: none; }
.pagination-prev, .pagination-next { width: auto; padding: 0 .75rem; gap: .3rem; }

/* ── Empty State ─────────────────────────────────────────── */
.empty-state { padding: 4rem 1.5rem; text-align: center; }
.empty-state .empty-icon { font-size: 3rem; margin-bottom: 1rem; opacity: .5; }
.empty-state h3 { margin-bottom: .5rem; }
.empty-state p  { color: var(--clr-muted); margin-bottom: 1.5rem; }

/* ── Form Controls ───────────────────────────────────────── */
.form-control {
  width: 100%; padding: .6rem .9rem; border: 1.5px solid var(--clr-border);
  border-radius: var(--radius-md); font-size: .9rem; color: var(--clr-text);
  background: var(--clr-bg); outline: none; transition: border-color .15s;
}
.form-control:focus { border-color: var(--clr-primary); background: #fff; }
.form-label { display: block; font-size: .875rem; font-weight: 600;
  color: var(--clr-text); margin-bottom: .35rem; }
.form-error { font-size: .8rem; color: var(--clr-danger); margin-top: .25rem; }
.form-group { margin-bottom: 1rem; }

/* ── Loading Spinner ─────────────────────────────────────── */
.spinner { display: inline-block; width: 20px; height: 20px;
  border: 2px solid var(--clr-border); border-top-color: var(--clr-primary);
  border-radius: 50%; animation: spin .6s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ══════════════════════════════════════════════════════════
   FICHE PRESTATAIRE
   ══════════════════════════════════════════════════════════ */

/* ── Hero ────────────────────────────────────────────────── */
.provider-hero { background: linear-gradient(135deg, #0f766e 0%, #0284c7 100%);
  color: #fff; padding: 2.5rem 0 2rem; }
.hero-content { display: flex; gap: 1.5rem; align-items: flex-start; flex-wrap: wrap; }
.hero-left { flex-shrink: 0; }
.hero-avatar-wrap { position: relative; display: inline-block; }
.hero-avatar { width: 96px; height: 96px; border-radius: 50%; object-fit: cover;
  border: 3px solid rgba(255,255,255,.4); background: rgba(255,255,255,.1); }
.hero-avatar-badge { position: absolute; bottom: 0; right: 0; width: 24px; height: 24px;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: .65rem; font-weight: 800; border: 2px solid #fff; }
.hero-info { flex: 1; min-width: 0; }
.hero-top { display: flex; flex-wrap: wrap; align-items: center; gap: .75rem; margin-bottom: .5rem; }
.hero-name { font-size: clamp(1.4rem, 3vw, 2rem); font-weight: 800; color: #fff; margin: 0; }
.hero-headline { font-size: 1rem; color: rgba(255,255,255,.85); margin-bottom: .75rem; }
.hero-meta { display: flex; flex-wrap: wrap; gap: .75rem; margin-bottom: .75rem; }
.hero-meta-item { font-size: .875rem; color: rgba(255,255,255,.8);
  display: flex; align-items: center; gap: .3rem; }
.hero-rating { display: flex; align-items: center; gap: .5rem; margin-bottom: .75rem; }
.rating-value-lg { font-size: 1.4rem; font-weight: 800; color: #fff; }
.rating-stars-lg { font-size: 1.1rem; }
.rating-stars-lg .star-full  { color: #fcd34d; }
.rating-stars-lg .star-half  { color: #fcd34d; opacity: .6; }
.rating-stars-lg .star-empty { color: rgba(255,255,255,.3); }
.rating-count-lg { font-size: .875rem; color: rgba(255,255,255,.7); }
.hero-cta { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: .75rem; }
.hero-cta .btn-outline { border-color: rgba(255,255,255,.5); color: #fff; }
.hero-cta .btn-outline:hover { background: rgba(255,255,255,.15); }

/* Bouton Favoris sur fond hero dégradé - border/texte blanc pour contraste */
.provider-hero .btn-fav {
  border-color: rgba(255,255,255,.55);
  color: #fff;
  background: rgba(255,255,255,.08);
}
.provider-hero .btn-fav:hover { background: rgba(255,255,255,.18); }
.provider-hero .btn-fav.favorited {
  background: rgba(239,68,68,.25);
  border-color: rgba(255,180,180,.6);
  color: #fff;
}

/* Badge vérification DÉTAILLÉ */
.badge-verified-full { display: inline-flex; align-items: center; gap: .4rem;
  padding: .35rem .75rem; border-radius: 99px; font-size: .8rem; font-weight: 700;
  cursor: default; position: relative; border: 1.5px solid transparent; }
.badge-verified-full.badge-none     { background: rgba(255,255,255,.1); color: rgba(255,255,255,.5); border-color: rgba(255,255,255,.2); }
.badge-verified-full.badge-identity { background: rgba(219,234,254,.9); color: #1d4ed8; border-color: #93c5fd; }
.badge-verified-full.badge-activity { background: rgba(204,251,241,.95); color: #0f766e; border-color: #5eead4; }
.badge-verified-full.badge-premium  { background: rgba(254,243,199,.95); color: #92400e; border-color: #fcd34d; }

.badge-icon { font-weight: 800; }
.badge-info-btn { background: none; border: none; cursor: pointer; font-size: .85rem;
  padding: 0 .2rem; opacity: .7; transition: opacity .15s; line-height: 1; }
.badge-info-btn:hover { opacity: 1; }

/* Tooltip card */
.badge-tooltip-card {
  display: none; position: absolute; top: calc(100% + 8px); left: 0;
  min-width: 280px; max-width: 320px; z-index: 200;
  background: var(--clr-surface); border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-lg);
  padding: 1rem 1.1rem; color: var(--clr-text);
  animation: fadeIn .15s ease;
}
.badge-tooltip-card.visible { display: block; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; } }
.tooltip-header { display: flex; align-items: center; gap: .5rem; margin-bottom: .6rem; }
.tooltip-header strong { font-size: .9rem; }
.tooltip-icon { font-size: 1rem; }
.tooltip-desc { font-size: .82rem; color: var(--clr-muted); margin-bottom: .75rem; line-height: 1.5; }
.tooltip-meta { border-top: 1px solid var(--clr-border); padding-top: .6rem; margin-bottom: .6rem; }
.tooltip-row { display: flex; justify-content: space-between; font-size: .8rem;
  color: var(--clr-muted); padding: .15rem 0; }
.tooltip-key { font-weight: 500; }
.tooltip-link { font-size: .8rem; color: var(--clr-primary); font-weight: 600; display: block; }
.tooltip-link:hover { text-decoration: underline; }

/* ── Provider Layout ─────────────────────────────────────── */
.provider-page { padding: 2rem 0 4rem; }
.provider-body { display: grid; grid-template-columns: 1fr; gap: 2rem; }
@media (min-width: 900px) {
  .provider-body { grid-template-columns: 1fr 300px; align-items: start; }
}
.provider-main { display: flex; flex-direction: column; gap: 0; }
.provider-section { background: var(--clr-surface); border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg); padding: 1.5rem; margin-bottom: 1.25rem; }
.section-title { font-size: 1.1rem; font-weight: 700; margin-bottom: 1rem;
  display: flex; align-items: center; gap: .5rem; }
.section-count { background: var(--clr-primary-l); color: var(--clr-primary);
  font-size: .75rem; font-weight: 700; padding: .15rem .5rem; border-radius: 99px; }

/* Bio */
.provider-bio { font-size: .95rem; color: var(--clr-muted); line-height: 1.8; white-space: pre-line; }

/* Skills */
.skills-cloud { display: flex; flex-wrap: wrap; gap: .5rem; }
.skill-tag-lg { background: var(--clr-primary-l); color: var(--clr-primary);
  border-radius: 99px; padding: .35rem .9rem; font-size: .875rem; font-weight: 500; }

/* Services */
.services-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 1rem; }
.service-card { background: var(--clr-bg); border: 1px solid var(--clr-border);
  border-radius: var(--radius-md); padding: 1rem; }
.service-category { font-size: .72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .05em; color: var(--clr-primary); margin-bottom: .4rem; }
.service-title { font-size: .95rem; font-weight: 600; margin-bottom: .4rem; }
.service-desc { font-size: .82rem; color: var(--clr-muted); margin-bottom: .5rem; line-height: 1.5; }
.service-price { font-size: .95rem; font-weight: 700; color: var(--clr-primary); margin-top: .5rem; }

/* Portfolio */
.portfolio-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: .75rem; }
.portfolio-item { border-radius: var(--radius-md); overflow: hidden;
  background: var(--clr-bg); border: 1px solid var(--clr-border); position: relative; }
.portfolio-img { width: 100%; height: 140px; object-fit: cover; cursor: zoom-in;
  transition: transform .2s; display: block; }
.portfolio-img:hover { transform: scale(1.03); }
.portfolio-caption { position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(15,23,42,.7));
  color: #fff; font-size: .72rem; padding: .5rem .6rem; }
.portfolio-video-link { display: flex; }
.portfolio-video-thumb { width: 100%; height: 140px; display: flex; align-items: center;
  justify-content: center; background: var(--clr-bg); color: var(--clr-primary);
  font-size: .875rem; font-weight: 600; cursor: pointer; transition: background .15s; }
.portfolio-video-thumb:hover { background: var(--clr-primary-l); }
.portfolio-project { padding: 1rem; }
.portfolio-project h4 { font-size: .9rem; margin-bottom: .3rem; }
.portfolio-project p  { font-size: .8rem; color: var(--clr-muted); margin-bottom: .5rem; }
.portfolio-project a  { font-size: .8rem; color: var(--clr-primary); font-weight: 600; }

/* Stats */
.stats-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(100px, 1fr)); gap: 1rem; }
.stat-block { text-align: center; background: var(--clr-bg); border-radius: var(--radius-md);
  padding: 1rem .75rem; border: 1px solid var(--clr-border); }
.stat-value { font-size: 1.5rem; font-weight: 800; color: var(--clr-primary); line-height: 1; margin-bottom: .3rem; }
.stat-label { font-size: .72rem; color: var(--clr-muted); text-transform: uppercase;
  letter-spacing: .04em; font-weight: 500; }

/* Reviews */
.review-aggregate { display: flex; gap: 2rem; margin-bottom: 1.5rem;
  padding: 1rem; background: var(--clr-bg); border-radius: var(--radius-md);
  border: 1px solid var(--clr-border); flex-wrap: wrap; }
.agg-score { text-align: center; flex-shrink: 0; }
.agg-value { font-size: 2.5rem; font-weight: 800; color: var(--clr-text); line-height: 1; }
.agg-stars { margin: .25rem 0; }
.agg-count { font-size: .8rem; color: var(--clr-muted); }
.review-distribution { flex: 1; min-width: 180px; display: flex; flex-direction: column; gap: .35rem; }
.dist-row { display: flex; align-items: center; gap: .6rem; font-size: .8rem; }
.dist-label { width: 22px; text-align: right; flex-shrink: 0; color: var(--clr-muted); }
.dist-bar-wrap { flex: 1; height: 8px; background: var(--clr-border); border-radius: 99px; overflow: hidden; }
.dist-bar { height: 100%; background: var(--clr-gold); border-radius: 99px; transition: width .4s ease; }
.dist-count { width: 20px; text-align: right; color: var(--clr-muted); flex-shrink: 0; }

.reviews-list { display: flex; flex-direction: column; gap: 1rem; }
.review-item { padding: 1rem; background: var(--clr-bg); border-radius: var(--radius-md);
  border: 1px solid var(--clr-border); }
.review-header { display: flex; justify-content: space-between; align-items: flex-start;
  flex-wrap: wrap; gap: .5rem; margin-bottom: .5rem; }
.reviewer-name { font-weight: 600; font-size: .875rem; }
.review-meta { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.review-stars .star-full  { color: var(--clr-gold); font-size: .85rem; }
.review-stars .star-half  { color: var(--clr-gold); font-size: .85rem; opacity: .6; }
.review-stars .star-empty { color: var(--clr-border); font-size: .85rem; }
.review-date { font-size: .8rem; }
.review-verified-badge { background: #dcfce7; color: #16a34a; font-size: .7rem;
  padding: .15rem .5rem; border-radius: 99px; font-weight: 600; }
.review-title   { font-size: .875rem; font-weight: 600; margin-bottom: .25rem; }
.review-comment { font-size: .875rem; color: var(--clr-muted); line-height: 1.6; }
.provider-response { margin-top: .75rem; padding: .75rem 1rem; background: var(--clr-primary-l);
  border-left: 3px solid var(--clr-primary); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; }
.provider-response strong { font-size: .8rem; color: var(--clr-primary); display: block; margin-bottom: .25rem; }
.provider-response p { font-size: .82rem; color: var(--clr-muted); margin: 0; }
.no-reviews { display: flex; flex-direction: column; align-items: center; gap: .5rem;
  text-align: center; padding: 2rem; color: var(--clr-muted); font-size: .9rem; }
.no-reviews i { font-size: 2rem; opacity: .35; }

/* ── En-tête section avis (titre + bouton) ───────────────── */
.reviews-section-header { display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: .75rem; margin-bottom: 1.25rem; }
.reviews-section-header .section-title { margin-bottom: 0; }

/* Bouton "Laisser un avis" - or/ambre pour se distinguer du bleu/vert primaire
   et contraster clairement sur le fond blanc de la section                      */
.btn-review-add { display: inline-flex; align-items: center; gap: .4rem;
  padding: .45rem 1rem; border-radius: var(--radius-full); font-size: .85rem;
  font-weight: 600; cursor: pointer; border: 2px solid var(--clr-gold);
  background: var(--clr-gold); color: #fff; transition: background var(--ease), transform var(--ease); }
.btn-review-add:hover { background: #b45309; border-color: #b45309; transform: translateY(-1px); }

.review-already-done { display: inline-flex; align-items: center; gap: .35rem;
  font-size: .82rem; color: var(--clr-success); font-weight: 500; }

/* ── Modal avis ──────────────────────────────────────────── */
.modal-overlay { position: fixed; inset: 0; z-index: 400; display: none;
  align-items: center; justify-content: center; padding: 1rem;
  background: rgba(15,23,42,.6); backdrop-filter: blur(3px); }
.modal-overlay.open { display: flex; }
.modal-box { background: var(--clr-surface); border-radius: var(--radius-lg);
  padding: 2rem; width: 100%; max-width: 500px; position: relative;
  box-shadow: var(--shadow-xl); max-height: 90vh; overflow-y: auto; }
.modal-close { position: absolute; top: 1rem; right: 1rem; background: none; border: none;
  cursor: pointer; color: var(--clr-muted); font-size: 1.25rem; line-height: 1;
  padding: .25rem; border-radius: var(--radius-sm); transition: color var(--ease); }
.modal-close:hover { color: var(--clr-danger); }
.modal-title { font-size: 1.2rem; font-weight: 800; margin-bottom: .25rem;
  display: flex; align-items: center; gap: .5rem; }
.modal-title i { color: var(--clr-gold); }
.modal-subtitle { font-size: .875rem; color: var(--clr-muted); margin-bottom: 1.5rem; }

/* ── Sélecteur étoiles (demi-étoiles incluses) ───────────── */
.star-picker { display: flex; gap: .2rem; margin-top: .35rem; }

/* Chaque "étoile" = 2 demi-zones cliquables côte à côte               */
.star-item { position: relative; display: inline-flex; cursor: pointer; line-height: 1; }

.star-half-zone,
.star-full-zone {
  display: inline-block;
  overflow: hidden;
  font-size: 2rem;
  color: var(--clr-border-2);
  transition: color var(--ease), transform var(--ease);
  background: none; border: none; cursor: pointer; padding: 0;
  line-height: 1;
}
.star-half-zone { width: 1rem; } /* moitié gauche */
.star-full-zone { width: 1rem; } /* moitié droite, icône décalée à gauche */
.star-full-zone i { margin-left: -1rem; } /* décale l'icône pour n'en voir que la moitié droite */

.star-item.active-full .star-half-zone,
.star-item.active-full .star-full-zone { color: var(--clr-gold); }
.star-item.active-half .star-half-zone { color: var(--clr-gold); }
.star-item.active-half .star-full-zone { color: var(--clr-border-2); }

.star-item:hover { transform: scale(1.1); }

/* Affichage de la note sélectionnée */
.star-rating-label {
  margin-top: .4rem;
  font-size: .82rem;
  color: var(--clr-gold);
  font-weight: 600;
  min-height: 1.2em;
}

/* Note de bas de formulaire */
.review-form-note { font-size: .75rem; color: var(--clr-subtle); text-align: center;
  margin-top: .75rem; display: flex; align-items: center; justify-content: center; gap: .3rem; }

/* ── Modal connexion requise ─────────────────────────────── */
.modal-box-sm { max-width: 380px; text-align: center; }
.modal-icon-lg { font-size: 3rem; color: var(--clr-primary); margin-bottom: .75rem; line-height: 1; }
.modal-icon-lg i { vertical-align: middle; }
.modal-body-text { font-size: .9rem; color: var(--clr-muted); margin-bottom: 1.5rem; line-height: 1.6; }
.modal-actions { display: flex; flex-direction: column; gap: .6rem; }

/* Toast notification */
.nj-toast { position: fixed; bottom: 1.5rem; left: 50%; transform: translateX(-50%);
  background: var(--clr-text); color: #fff; padding: .65rem 1.25rem;
  border-radius: var(--radius-full); font-size: .875rem; font-weight: 500;
  z-index: 600; box-shadow: var(--shadow-lg); white-space: nowrap;
  animation: toastIn .2s ease; pointer-events: none; }
.nj-toast.toast-success { background: var(--clr-success); }
.nj-toast.toast-error   { background: var(--clr-danger); }
@keyframes toastIn { from { opacity: 0; transform: translateX(-50%) translateY(8px); } to { opacity: 1; transform: translateX(-50%) translateY(0); } }

/* Avis optimiste (pending, visible seulement pour l'auteur) */
.review-item.review-pending { border: 1.5px dashed var(--clr-gold); background: var(--clr-gold-l); }
.review-pending-badge { display: inline-flex; align-items: center; gap: .3rem;
  font-size: .75rem; color: #92400e; font-weight: 600;
  background: #fef3c7; border: 1px solid #fcd34d; border-radius: var(--radius-full);
  padding: .15rem .5rem; margin-top: .35rem; }

/* ── Sticky CTA Sidebar ──────────────────────────────────── */
.provider-sidebar { position: relative; }
.sticky-cta { position: sticky; top: 80px; }
.cta-card { background: var(--clr-surface); border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg); padding: 1.5rem; }
.cta-title { font-size: 1rem; font-weight: 700; margin-bottom: .75rem; }
.cta-rating { margin-bottom: 1rem; display: flex; align-items: center; gap: .5rem; }
.cta-group { display: flex; flex-direction: column; gap: .6rem; margin-bottom: 1rem; }
.cta-meta { border-top: 1px solid var(--clr-border); padding-top: .75rem;
  margin-bottom: .75rem; display: flex; flex-direction: column; gap: .4rem; }
.cta-meta-row { display: flex; justify-content: space-between; font-size: .82rem; color: var(--clr-muted); }
.cta-note { font-size: .75rem; color: var(--clr-subtle); line-height: 1.5; }

/* ── Mobile sticky CTA (bottom bar) ─────────────────────── */
.mobile-sticky-cta { display: flex; gap: .5rem; position: fixed; bottom: 0; left: 0; right: 0;
  padding: .75rem 1rem calc(.75rem + env(safe-area-inset-bottom));
  background: var(--clr-surface); border-top: 1px solid var(--clr-border);
  z-index: 90; box-shadow: 0 -4px 12px rgba(0,0,0,.08); }
.mobile-sticky-cta .btn { flex: 1; justify-content: center; }
@media (min-width: 900px) {
  .mobile-sticky-cta { display: none; }
  .provider-page { padding-bottom: 2rem; }
}

/* ── Lightbox ────────────────────────────────────────────── */
.lightbox { display: none; position: fixed; inset: 0; z-index: 500;
  background: rgba(15,23,42,.92); align-items: center; justify-content: center; }
.lightbox.open { display: flex; }
.lightbox-inner { position: relative; max-width: 90vw; max-height: 88vh; }
.lightbox-inner img { max-width: 90vw; max-height: 84vh; border-radius: var(--radius-md);
  object-fit: contain; display: block; }
.lightbox-close { position: absolute; top: -40px; right: 0; background: none; border: none;
  color: #fff; font-size: 1.5rem; cursor: pointer; padding: .5rem; line-height: 1; }
.lightbox-caption { position: absolute; bottom: -32px; left: 0; right: 0;
  color: rgba(255,255,255,.7); font-size: .8rem; text-align: center; }

/* ===============================================================
   AUTH PAGES
   =============================================================== */
.auth-page { min-height: calc(100vh - 64px); display: flex; align-items: center;
  justify-content: center; padding: 2rem 1rem; background: var(--clr-bg); }
.auth-card { background: var(--clr-surface); border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg); padding: 2.5rem; width: 100%; max-width: 420px;
  box-shadow: var(--shadow-md); }
.auth-card-wide { max-width: 600px; }
.auth-title    { font-size: 1.5rem; font-weight: 800; margin-bottom: .25rem; }
.auth-subtitle { color: var(--clr-muted); font-size: .9rem; margin-bottom: 1.5rem; }
.auth-form     { display: flex; flex-direction: column; gap: .1rem; }
.auth-links    { display: flex; justify-content: space-between; flex-wrap: wrap;
  gap: .5rem; margin-top: 1rem; font-size: .85rem; }
.auth-links a  { color: var(--clr-primary); }
.auth-links a:hover { text-decoration: underline; }
.auth-terms    { font-size: .75rem; color: var(--clr-subtle); text-align: center;
  margin-top: .75rem; line-height: 1.5; }
.auth-terms a  { color: var(--clr-muted); }
.form-row      { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-hint     { font-size: .75rem; color: var(--clr-subtle); display: block; margin-top: .2rem; }
.form-banner-error { background: #fef2f2; border: 1px solid #fca5a5; color: #dc2626;
  padding: .65rem 1rem; border-radius: var(--radius-md); font-size: .875rem; margin-bottom: 1rem; }
.flash-banner  { background: #f0fdf4; border-bottom: 1px solid #86efac; color: #16a34a;
  padding: .75rem 1rem; text-align: center; font-size: .875rem; font-weight: 500; }
@media (max-width: 520px) { .form-row { grid-template-columns: 1fr; } }
.role-selector { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; margin-bottom: 1.5rem; }
.role-option   { cursor: pointer; }
.role-option input { display: none; }
.role-option-content { display: flex; flex-direction: column; align-items: center;
  gap: .3rem; padding: 1.1rem .75rem; border: 2px solid var(--clr-border);
  border-radius: var(--radius-md); text-align: center; transition: all .15s; }
.role-option-content strong { font-size: .875rem; }
.role-option-content span { font-size: .75rem; color: var(--clr-muted); }
.role-icon { font-size: 1.75rem; }
.role-option.active .role-option-content { border-color: var(--clr-primary); background: var(--clr-primary-l); }
.role-option-content:hover { border-color: var(--clr-primary); }

/* ===============================================================
   DASHBOARD
   =============================================================== */
.dashboard-layout { display: grid; grid-template-columns: 240px 1fr; min-height: calc(100vh - 64px); align-items: start; }
@media (max-width: 768px) { .dashboard-layout { grid-template-columns: 1fr; } }
.dash-sidebar { background: var(--clr-surface); border-right: 1px solid var(--clr-border);
  padding: 1.5rem 1rem; position: sticky; top: 64px; height: calc(100vh - 64px); overflow-y: auto; }
@media (max-width: 768px) { .dash-sidebar { position: static; height: auto; border-right: none;
  border-bottom: 1px solid var(--clr-border); padding: 1rem; } }
.dash-user { display: flex; align-items: center; gap: .75rem; padding: .75rem;
  margin-bottom: 1rem; border-radius: var(--radius-md); background: var(--clr-bg); }
.dash-avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--clr-primary);
  color: #fff; font-weight: 700; font-size: 1.1rem; display: flex; align-items: center;
  justify-content: center; flex-shrink: 0; }
.dash-user-name { font-weight: 600; font-size: .875rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 130px; }
.dash-user-role { font-size: .75rem; color: var(--clr-muted); }
.dash-nav { display: flex; flex-direction: column; gap: .15rem; }
@media (max-width: 768px) { .dash-nav { flex-direction: row; flex-wrap: wrap; gap: .4rem; } }
.dash-nav-item { display: flex; align-items: center; gap: .5rem; padding: .6rem .85rem;
  border-radius: var(--radius-sm); font-size: .875rem; color: var(--clr-muted);
  transition: background .15s, color .15s; font-weight: 500; }
.dash-nav-item:hover { background: var(--clr-bg); color: var(--clr-text); }
.dash-nav-item.active { background: var(--clr-primary-l); color: var(--clr-primary); font-weight: 600; }
.dash-nav-divider { height: 1px; background: var(--clr-border); margin: .5rem 0; }
.dash-nav-logout { color: var(--clr-danger); }
.dash-nav-logout:hover { background: #fef2f2; color: var(--clr-danger); }
.dash-main { padding: 1.5rem 2rem; }
@media (max-width: 768px) { .dash-main { padding: 1rem; } }
.dash-header { display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 1.5rem; flex-wrap: wrap; gap: .75rem; }
.dash-title  { font-size: 1.4rem; font-weight: 700; }
.dash-stats-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 1rem; margin-bottom: 1.5rem; }
.stat-card       { background: var(--clr-surface); border: 1px solid var(--clr-border);
  border-radius: var(--radius-md); padding: 1.25rem 1rem; text-align: center; }
.stat-card-value { font-size: 1.75rem; font-weight: 800; color: var(--clr-primary); line-height: 1; margin-bottom: .35rem; }
.stat-card-label { font-size: .75rem; color: var(--clr-muted); text-transform: uppercase; letter-spacing: .04em; font-weight: 500; }
.stat-card-link  { display: block; margin-top: .5rem; font-size: .8rem; color: var(--clr-primary); font-weight: 600; }
.dash-section { background: var(--clr-surface); border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg); padding: 1.5rem; margin-bottom: 1.25rem; }
.dash-section h2 { font-size: 1rem; font-weight: 700; margin-bottom: 1rem; }
.dash-section-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1rem; }
.dash-section-header h2 { margin-bottom: 0; }
.mini-cards-grid { display: grid; grid-template-columns: 1fr; gap: .6rem; }
.mini-cards-full { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.mini-card { display: flex; align-items: center; gap: .75rem; padding: .85rem 1rem;
  background: var(--clr-bg); border-radius: var(--radius-md); border: 1px solid var(--clr-border);
  transition: box-shadow .15s; text-decoration: none; color: var(--clr-text); }
.mini-card:hover { box-shadow: var(--shadow-sm); }
.mini-card-avatar { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; flex-shrink: 0; background: var(--clr-border); }
.mini-card-info  { flex: 1; min-width: 0; }
.mini-card-name  { font-size: .9rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mini-card-meta  { font-size: .78rem; color: var(--clr-muted); margin-top: .1rem; }
.mini-card-action  { font-size: .8rem; color: var(--clr-primary); font-weight: 600; flex-shrink: 0; }
.mini-card-actions { display: flex; gap: .4rem; flex-shrink: 0; }
.history-list, .history-table { display: flex; flex-direction: column; gap: .5rem; }
.history-row { display: flex; align-items: center; gap: .75rem; padding: .6rem .75rem;
  background: var(--clr-bg); border-radius: var(--radius-sm); font-size: .875rem; flex-wrap: wrap; }
.history-icon    { font-size: 1rem; flex-shrink: 0; }
.history-name    { font-weight: 500; color: var(--clr-text); flex: 1; }
.history-name:hover { color: var(--clr-primary); }
.history-channel { font-size: .75rem; background: var(--clr-primary-l); color: var(--clr-primary);
  padding: .15rem .5rem; border-radius: 99px; font-weight: 600; }
.history-date, .history-location { font-size: .78rem; }
.dash-empty { text-align: center; padding: 3rem 1.5rem; color: var(--clr-muted); }
.dash-empty-icon { font-size: 2.5rem; margin-bottom: .75rem; }
.dash-empty h3   { font-size: 1.1rem; font-weight: 700; color: var(--clr-text); margin-bottom: .4rem; }
.dash-empty p    { margin-bottom: 1.25rem; }
.contact-channels { display: flex; flex-direction: column; gap: .5rem; }
.channel-row { display: flex; align-items: center; gap: .75rem; font-size: .875rem; }
.channel-icon  { font-size: 1rem; width: 20px; text-align: center; flex-shrink: 0; }
.channel-label { width: 90px; color: var(--clr-muted); flex-shrink: 0; }
.channel-bar-wrap { flex: 1; height: 8px; background: var(--clr-border); border-radius: 99px; overflow: hidden; }
.channel-bar { height: 100%; background: var(--clr-primary); border-radius: 99px; }
.channel-count { width: 24px; text-align: right; font-weight: 600; color: var(--clr-text); }
.quick-actions { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 1rem; }
.quick-action-btn { display: flex; flex-direction: column; gap: .3rem; padding: 1.1rem 1rem;
  background: var(--clr-bg); border: 1px solid var(--clr-border); border-radius: var(--radius-md);
  cursor: pointer; transition: all .15s; text-decoration: none; color: var(--clr-text); }
.quick-action-btn:hover { border-color: var(--clr-primary); background: var(--clr-primary-l); }
.quick-action-btn span   { font-size: 1.5rem; }
.quick-action-btn strong { font-size: .875rem; }
.quick-action-btn small  { font-size: .75rem; color: var(--clr-muted); }
.verification-status { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.dash-form { display: flex; flex-direction: column; gap: 0; }
.dash-form-footer { display: flex; align-items: center; gap: 1rem; padding-top: 1rem; margin-top: .5rem; }
.checkbox-group { display: flex; gap: 1.5rem; flex-wrap: wrap; }
.checkbox-label { display: flex; align-items: center; gap: .5rem; font-size: .9rem; cursor: pointer; }
.checkbox-label input { width: 16px; height: 16px; accent-color: var(--clr-primary); }
.toggle-label-row { display: flex; align-items: center; gap: .75rem; cursor: pointer; font-size: .875rem; }
.toggle-label-row input { width: 18px; height: 18px; accent-color: var(--clr-primary); }
.settings-form { display: flex; flex-direction: column; gap: .1rem; }
.settings-info-row { display: flex; gap: 1rem; font-size: .875rem; padding: .4rem 0;
  border-bottom: 1px solid var(--clr-border); }
.settings-info-row:last-child { border-bottom: none; }
.btn-fav { padding: .5rem .75rem; font-size: .9rem; transition: all .2s; }
.btn-fav.favorited { color: #dc2626; border-color: #dc2626; }
.btn-fav.favorited:hover { background: #fef2f2; }

/* PAGE VERIFICATION PUBLIC */
.verif-hero{background:linear-gradient(135deg,#0f172a,#1e3a5f);color:#fff;padding:4rem 0 3rem;text-align:center}
.verif-hero-content{max-width:680px;margin-inline:auto}
.verif-hero-badge{display:flex;justify-content:center;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap}
.verif-hero h1{color:#fff;margin-bottom:.75rem}
.verif-hero-lead{color:rgba(255,255,255,.75);font-size:1.05rem;line-height:1.7;margin-bottom:1.75rem}
.verif-section{padding:3rem 0}
.verif-section-title{text-align:center;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}
.verif-section-sub{text-align:center;color:var(--clr-muted);margin-bottom:2rem}
.level-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}
.level-card{background:var(--clr-surface);border-radius:var(--radius-lg);overflow:hidden;border:2px solid var(--clr-border);display:flex;flex-direction:column}
.level-card.level-identity{border-color:#93c5fd}.level-card.level-activity{border-color:#5eead4}.level-card.level-premium{border-color:#fcd34d}
.level-card-header{padding:1.25rem;text-align:center}
.level-card.level-identity .level-card-header{background:#eff6ff}.level-card.level-activity .level-card-header{background:#f0fdfa}.level-card.level-premium .level-card-header{background:#fffbeb}
.level-badge{display:inline-block;margin-bottom:.75rem;font-size:.75rem;font-weight:700;padding:.3rem .75rem;border-radius:99px}
.level-card-header h3{font-size:1.1rem;margin:0}
.level-icon{font-size:2rem;margin-top:.5rem}
.level-card-body{padding:1.25rem;flex:1;display:flex;flex-direction:column;gap:.9rem}
.level-desc{font-size:.875rem;color:var(--clr-muted);line-height:1.6}
.level-docs-title,.level-guarantees-title,.level-limits-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--clr-subtle);margin-bottom:.35rem}
.level-docs ul,.level-guarantees ul,.level-limits ul{font-size:.82rem;padding-left:1rem;line-height:1.7}
.level-guarantees ul li{color:var(--clr-success)}.level-limits ul li{color:var(--clr-danger)}
.level-timing{font-size:.78rem;color:var(--clr-muted);font-style:italic;margin-top:auto;padding-top:.75rem;border-top:1px solid var(--clr-border)}
.verif-process-section{background:#f1f5f9}
.process-steps{display:flex;flex-direction:column;gap:0}
.process-step{display:flex;gap:1.25rem;align-items:flex-start;padding:1rem 0;border-bottom:1px solid var(--clr-border)}
.process-step:last-child{border-bottom:none}
.process-num{width:36px;height:36px;border-radius:50%;background:var(--clr-primary);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.9rem}
.process-content h4{font-size:.95rem;font-weight:700;margin-bottom:.25rem}
.process-content p{font-size:.875rem;color:var(--clr-muted);line-height:1.6;margin:0}
.verif-limits-box{background:#fff7ed;border:2px solid #fed7aa;border-radius:var(--radius-lg);padding:2rem}
.verif-limits-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}
.verif-limits-icon{font-size:1.5rem}
.verif-limits-header h2{font-size:1.2rem;margin:0}
.verif-limits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}
.verif-limit-item{background:#fff;border-radius:var(--radius-md);padding:1rem;border:1px solid #fed7aa}
.verif-limit-item strong{display:block;font-size:.875rem;margin-bottom:.25rem}
.verif-limit-item span{font-size:.82rem;color:var(--clr-muted);line-height:1.6}
.verif-faq{display:flex;flex-direction:column;gap:.5rem}
.verif-faq-item{border:1px solid var(--clr-border);border-radius:var(--radius-md);overflow:hidden}
.verif-faq-item summary{padding:1rem 1.25rem;cursor:pointer;font-weight:600;font-size:.9rem;list-style:none;display:flex;justify-content:space-between;align-items:center;background:var(--clr-surface)}
.verif-faq-item summary::-webkit-details-marker{display:none}
.verif-faq-item p{padding:1rem 1.25rem;font-size:.875rem;color:var(--clr-muted);line-height:1.7;background:var(--clr-bg);margin:0}
.verif-cta-section{background:var(--clr-primary);color:#fff;padding:3rem 0;text-align:center}
.verif-cta-section h2{color:#fff;margin-bottom:.5rem}
.verif-cta-btns{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}
.verif-status-card{border-left:4px solid var(--clr-primary)}
.verif-current-level{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}
.verif-progress{display:flex;align-items:center;gap:0;flex-wrap:nowrap;overflow-x:auto;padding:.5rem 0}
.verif-progress-step{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.5rem .75rem;border-radius:var(--radius-md);min-width:80px;text-align:center;background:var(--clr-bg);border:2px solid var(--clr-border)}
.verif-progress-step.done{border-color:var(--clr-primary);background:var(--clr-primary-l)}
.verif-progress-step.active{border-color:var(--clr-gold);background:#fffbeb}
.vps-icon{font-size:1.25rem}.vps-label{font-size:.7rem;font-weight:600;color:var(--clr-muted)}
.verif-progress-step.done .vps-label{color:var(--clr-primary)}.verif-progress-step.active .vps-label{color:var(--clr-gold)}
.vps-line{flex:1;height:2px;background:var(--clr-border);min-width:24px}.vps-line.done{background:var(--clr-primary)}
.verif-pending-card{background:#fefce8;border-color:#fde047}
.verif-pending-header{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}
.status-badge{font-size:.75rem;font-weight:700;padding:.25rem .6rem;border-radius:99px}
.status-pending{background:#fef3c7;color:#92400e}.status-approved{background:#dcfce7;color:#16a34a}.status-rejected{background:#fef2f2;color:var(--clr-danger)}.status-expired{background:#f1f5f9;color:var(--clr-subtle)}
.verif-premium-card{border-left:4px solid var(--clr-gold);background:#fffbeb}
.upload-form{display:flex;flex-direction:column;gap:.75rem}
.upload-field{border:2px dashed var(--clr-border);border-radius:var(--radius-md);padding:1.25rem;cursor:pointer;transition:border-color .15s}
.upload-field:hover{border-color:var(--clr-primary)}
.upload-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.875rem;color:var(--clr-muted)}
.upload-icon{font-size:1.5rem}
.verif-history{display:flex;flex-direction:column;gap:.6rem}
.verif-history-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding:.6rem .75rem;background:var(--clr-bg);border-radius:var(--radius-sm);font-size:.875rem}
.verif-reject-reason{font-size:.78rem;color:var(--clr-danger);font-style:italic;width:100%}
.admin-verif-list{display:flex;flex-direction:column;gap:1.25rem}
.admin-verif-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.25rem}
.admin-verif-header{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem}
.admin-verif-docs{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}
.admin-doc-tag{font-size:.78rem;background:var(--clr-bg);border:1px solid var(--clr-border);padding:.2rem .6rem;border-radius:var(--radius-sm);color:var(--clr-muted)}
.admin-verif-actions{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}

/* WIDGET VERIFICATION PERMANENT */
.verif-widget{display:flex;align-items:center;gap:1rem;background:var(--clr-surface);border-radius:var(--radius-lg);padding:1rem 1.25rem;margin:1.5rem 0;border:2px solid var(--clr-border);box-shadow:var(--shadow-sm);flex-wrap:wrap}
.verif-widget-identity{border-color:#93c5fd;background:linear-gradient(to right,#eff6ff,#fff)}
.verif-widget-activity{border-color:#5eead4;background:linear-gradient(to right,#f0fdfa,#fff)}
.verif-widget-premium{border-color:#fcd34d;background:linear-gradient(to right,#fffbeb,#fff)}
.verif-widget-icon{font-size:2rem;flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--clr-bg)}
.verif-widget-identity .verif-widget-icon{background:#dbeafe;color:#1d4ed8}
.verif-widget-activity .verif-widget-icon{background:var(--clr-primary-l);color:var(--clr-primary)}
.verif-widget-premium .verif-widget-icon{background:#fef3c7;color:#92400e}
.verif-widget-content{flex:1;min-width:200px}
.verif-widget-title{font-size:1rem;display:flex;align-items:baseline;gap:.4rem}
.verif-widget-title strong{font-weight:700}
.verif-widget-by{font-size:.75rem;color:var(--clr-muted);font-weight:500}
.verif-widget-meta{font-size:.82rem;color:var(--clr-muted);margin-top:.2rem;display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}
.verif-widget-meta strong{color:var(--clr-text);font-weight:600}
.verif-widget-sep{color:var(--clr-subtle)}
.verif-widget-link{font-size:.85rem;color:var(--clr-primary);font-weight:600;flex-shrink:0;white-space:nowrap;text-decoration:none}
.verif-widget-link:hover{text-decoration:underline}
@media (max-width: 600px){.verif-widget{flex-direction:column;align-items:flex-start;text-align:left}}

/* MESSAGERIE / CHAT */
.messages-page-layout { min-height: calc(100vh - 64px); }
.messages-main { padding: 0 !important; }
.messages-layout { display: grid; grid-template-columns: 280px 1fr; height: calc(100vh - 64px); overflow: hidden; }
@media (max-width: 768px) { .messages-layout { grid-template-columns: 1fr; } }

/* Liste conversations */
.conv-list-panel { background: var(--clr-surface); border-right: 1px solid var(--clr-border); display: flex; flex-direction: column; overflow: hidden; }
.conv-list-header { padding: 1rem 1.25rem; border-bottom: 1px solid var(--clr-border); display: flex; align-items: center; gap: .75rem; flex-shrink: 0; }
.conv-list-header h2 { font-size: 1rem; font-weight: 700; }
.conv-list { flex: 1; overflow-y: auto; }
.conv-item { display: flex; align-items: center; gap: .75rem; padding: .9rem 1.1rem; text-decoration: none; color: var(--clr-text); border-bottom: 1px solid var(--clr-border); transition: background .12s; cursor: pointer; }
.conv-item:hover { background: var(--clr-bg); }
.conv-item.active { background: var(--clr-primary-l); border-right: 3px solid var(--clr-primary); }
.conv-avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--clr-primary); color: #fff; font-weight: 700; font-size: 1rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.conv-info { flex: 1; min-width: 0; }
.conv-name { font-size: .875rem; font-weight: 600; display: flex; align-items: center; gap: .4rem; }
.conv-preview { font-size: .78rem; color: var(--clr-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: .1rem; }
.conv-time { font-size: .72rem; color: var(--clr-subtle); flex-shrink: 0; }
.conv-unread-badge { background: var(--clr-primary); color: #fff; font-size: .65rem; font-weight: 700; border-radius: 99px; padding: .1rem .4rem; line-height: 1.5; }
.conv-empty { padding: 2rem 1.25rem; text-align: center; color: var(--clr-muted); font-size: .875rem; }
.conv-empty small { display: block; margin-top: .4rem; font-size: .78rem; color: var(--clr-subtle); }

/* Panneau chat */
.chat-panel { display: flex; flex-direction: column; background: #f8fafc; overflow: hidden; }
.chat-header { display: flex; align-items: center; gap: .75rem; padding: .85rem 1.25rem; background: var(--clr-surface); border-bottom: 1px solid var(--clr-border); flex-shrink: 0; }
.chat-back { font-size: 1.25rem; color: var(--clr-primary); text-decoration: none; flex-shrink: 0; display: none; }
@media (max-width: 768px) { .chat-back { display: block; } }
.chat-avatar { width: 38px; height: 38px; border-radius: 50%; background: var(--clr-primary); color: #fff; font-weight: 700; font-size: .95rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.chat-header-info strong { font-size: .95rem; font-weight: 700; display: block; }
.chat-profile-link { font-size: .78rem; color: var(--clr-primary); }
.chat-profile-link:hover { text-decoration: underline; }

/* Messages scrollables */
.chat-messages { flex: 1; overflow-y: auto; padding: 1.25rem; display: flex; flex-direction: column; gap: .35rem; }
.msg-date-sep { text-align: center; font-size: .72rem; color: var(--clr-subtle); margin: .75rem 0; padding: .2rem .75rem; background: var(--clr-surface); border-radius: 99px; display: inline-block; align-self: center; }

/* Bulles de message */
.message-row { display: flex; }
.message-row.mine   { justify-content: flex-end; }
.message-row.theirs { justify-content: flex-start; }
.message-bubble { max-width: 72%; padding: .6rem .9rem; border-radius: 16px; line-height: 1.5; }
.message-row.mine   .message-bubble { background: var(--clr-primary); color: #fff; border-bottom-right-radius: 4px; }
.message-row.theirs .message-bubble { background: var(--clr-surface); border: 1px solid var(--clr-border); border-bottom-left-radius: 4px; }
.message-text { font-size: .875rem; word-wrap: break-word; white-space: pre-wrap; }
.message-meta { display: flex; justify-content: flex-end; align-items: center; gap: .3rem; margin-top: .25rem; }
.message-time { font-size: .68rem; opacity: .7; }
.message-read { font-size: .68rem; opacity: .8; }
.message-row.mine .message-time { color: rgba(255,255,255,.75); }
.message-row.mine .message-read { color: #a5f3e0; }

/* Zone de saisie */
.chat-input-area { display: flex; align-items: flex-end; gap: .5rem; padding: .85rem 1rem; background: var(--clr-surface); border-top: 1px solid var(--clr-border); flex-shrink: 0; }
.chat-textarea { flex: 1; resize: none; border: 1.5px solid var(--clr-border); border-radius: var(--radius-lg); padding: .65rem .9rem; font-size: .9rem; max-height: 120px; outline: none; background: var(--clr-bg); line-height: 1.5; transition: border-color .15s; }
.chat-textarea:focus { border-color: var(--clr-primary); background: #fff; }
.chat-send-btn { width: 42px; height: 42px; border-radius: 50%; padding: 0; display: flex; align-items: center; justify-content: center; font-size: 1rem; flex-shrink: 0; }

/* Messages vides / welcome */
.chat-welcome, .chat-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; flex: 1; padding: 3rem 1.5rem; text-align: center; color: var(--clr-muted); }
.chat-welcome-icon { font-size: 3rem; margin-bottom: 1rem; opacity: .5; }
.chat-welcome h3 { font-size: 1.1rem; font-weight: 700; color: var(--clr-text); margin-bottom: .4rem; }

/* Badge non-lus dans la nav */
.nav-badge { background: #dc2626; color: #fff; font-size: .65rem; font-weight: 800; border-radius: 99px; padding: .1rem .4rem; line-height: 1.4; position: absolute; top: -4px; right: -6px; min-width: 18px; text-align: center; }

/* =====================================================
   HOME PAGE
   ===================================================== */

/* Hero */
.hero{background:linear-gradient(135deg,#0a4d45 0%,#0f766e 40%,#0284c7 100%);color:#fff;padding:4.5rem 0 4rem;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width=60 height=60 xmlns=http://www.w3.org/2000/svg%3E%3Ccircle cx=30 cy=30 r=1 fill=rgba(255,255,255,.06)/%3E%3C/svg%3E");pointer-events:none}
.hero-content{max-width:680px}
.hero-label{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);font-size:.8rem;font-weight:600;padding:.35rem .85rem;border-radius:99px;margin-bottom:1.25rem;backdrop-filter:blur(8px)}
.hero h1{color:#fff;margin-bottom:.9rem}
.hero .text-lead{color:rgba(255,255,255,.82);margin-bottom:2rem;max-width:580px}
.hero .search-bar-wrap{background:rgba(255,255,255,.12);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);margin-bottom:1.25rem}
.hero .search-field input{background:rgba(255,255,255,.92);color:var(--clr-text)}
.hero .search-field input:focus{background:#fff}
.hero-trust-tags{display:flex;flex-wrap:wrap;gap:.5rem}
.hero-tag{background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);font-size:.78rem;font-weight:500;padding:.3rem .7rem;border-radius:99px;backdrop-filter:blur(4px)}

/* Category grid */
.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}
.category-card{background:var(--clr-surface);border:1.5px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.25rem 1rem;text-align:center;text-decoration:none;color:var(--clr-text);display:flex;flex-direction:column;align-items:center;gap:.4rem;transition:all var(--ease);cursor:pointer}
.category-card:hover{border-color:var(--clr-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.category-icon{font-size:2rem;line-height:1;display:block}
.category-name{font-size:.875rem;font-weight:700;line-height:1.3}
.category-count{font-size:.72rem;color:var(--clr-muted)}

/* How it works */
.how-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:2rem}
.how-step{position:relative;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:2rem 1.5rem;text-align:center}
.how-step-num{position:absolute;top:-1rem;left:50%;transform:translateX(-50%);width:2rem;height:2rem;border-radius:50%;background:var(--clr-primary);color:#fff;font-weight:800;font-size:.875rem;display:flex;align-items:center;justify-content:center}
.how-step-icon{font-size:2.5rem;margin-bottom:.75rem;display:block}
.how-step h3{margin-bottom:.5rem}
.how-step p{font-size:.875rem;color:var(--clr-muted);line-height:1.6;margin:0}

/* Stats */
.home-stats-section{background:linear-gradient(135deg,var(--clr-primary),#0284c7)}
.home-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
.home-stat-value{font-size:clamp(2rem,4vw,3rem);font-weight:900;color:#fff;line-height:1;margin-bottom:.35rem}
.home-stat-label{font-size:.85rem;color:rgba(255,255,255,.75);line-height:1.4}

/* Trust block */
.trust-block{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
@media(max-width:767px){.trust-block{grid-template-columns:1fr}}
.trust-badge-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}
.trust-block-text h2{margin-bottom:.75rem}
.trust-block-text p{margin-bottom:0}
.trust-levels{display:flex;flex-direction:column;gap:.6rem}
.trust-level{display:flex;align-items:center;gap:.85rem;padding:.75rem 1rem;border-radius:var(--radius-md);border:2px solid var(--clr-border);background:var(--clr-bg)}
.trust-none{border-color:#e2e8f0;background:#f8fafc}
.trust-id{border-color:#93c5fd;background:#eff6ff}
.trust-act{border-color:#5eead4;background:#f0fdfa}
.trust-prem{border-color:#fcd34d;background:#fffbeb}
.trust-level-icon{font-size:1.5rem;flex-shrink:0}
.trust-level-label{font-weight:700;font-size:.875rem;flex:1}
.trust-level-sub{font-size:.75rem;color:var(--clr-muted)}

/* CTA Prestataires */
.home-provider-cta{background:linear-gradient(135deg,#0f172a,#1e293b);color:#fff;padding:4rem 0}
.home-provider-cta-inner{display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}
.home-provider-cta h2{color:#fff;margin-bottom:.6rem}
.home-provider-cta p{color:rgba(255,255,255,.7);max-width:500px;font-size:.95rem;margin:0}
.home-provider-cta-actions{display:flex;gap:1rem;flex-shrink:0;flex-wrap:wrap}

/* =====================================================
   GLOBAL POLISH
   ===================================================== */

/* Meilleur flash banner */
.flash-banner{display:flex;align-items:center;justify-content:center;gap:.5rem;background:linear-gradient(90deg,#f0fdf4,#ecfdf5);border-bottom:1px solid #86efac;color:#15803d;padding:.7rem 1rem;font-size:.875rem;font-weight:500}
.flash-banner::before{content:"✓";font-weight:800}

/* Amélioration des form controls */
.form-group{margin-bottom:1.1rem}
.form-control{transition:border-color var(--ease),box-shadow var(--ease)}
.form-control:focus{border-color:var(--clr-primary);box-shadow:0 0 0 3px rgba(15,118,110,.1)}

/* Section de contenu générique */
.content-page{padding:3rem 0;max-width:760px;margin-inline:auto}
.content-page h1{margin-bottom:.5rem}
.content-page h2{margin-top:2.5rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:2px solid var(--clr-border)}
.content-page p{color:var(--clr-muted);line-height:1.8;margin-bottom:1rem}
.content-page ul{padding-left:1.5rem;color:var(--clr-muted);line-height:1.8;list-style:disc;margin-bottom:1rem}

/* 404 / 500 pages */
.error-page{min-height:calc(100vh - 128px);display:flex;align-items:center;justify-content:center;padding:2rem}
.error-card{text-align:center;max-width:480px;width:100%}
.error-code{font-size:6rem;font-weight:900;color:var(--clr-border);line-height:1;margin-bottom:.5rem}
.error-card h1{font-size:1.5rem;margin-bottom:.5rem}
.error-card p{margin-bottom:2rem}
.error-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* HOW IT WORKS */
.hiw-hero{background:linear-gradient(135deg,#0f766e,#0284c7);color:#fff;padding:4rem 0 3rem;text-align:center}
.hiw-hero h1{color:#fff;margin-bottom:.75rem}
.hiw-hero .text-lead{color:rgba(255,255,255,.82);margin-bottom:1.75rem}
.hiw-tabs{display:inline-flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-top:.75rem}
.hiw-tab{background:rgba(255,255,255,.15);color:#fff;padding:.45rem 1.1rem;border-radius:99px;font-size:.875rem;font-weight:600;text-decoration:none;backdrop-filter:blur(4px);transition:background var(--ease)}
.hiw-tab:hover,.hiw-tab.active{background:rgba(255,255,255,.3)}
.hiw-section-header{text-align:center;margin-bottom:2.5rem}
.hiw-section-pill{display:inline-block;background:var(--clr-primary-l);color:var(--clr-primary);font-size:.78rem;font-weight:700;padding:.3rem .85rem;border-radius:99px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.85rem}
.hiw-pill-green{background:#dcfce7;color:#16a34a}
.hiw-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-bottom:2rem}
.hiw-step{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:2rem;position:relative}
.hiw-step-num{position:absolute;top:1.25rem;right:1.25rem;width:28px;height:28px;border-radius:50%;background:var(--clr-primary);color:#fff;font-weight:800;font-size:.8rem;display:flex;align-items:center;justify-content:center}
.hiw-step-icon{font-size:2.25rem;margin-bottom:.85rem;display:block}
.hiw-step h3{margin-bottom:.5rem}
.hiw-step p{font-size:.875rem;color:var(--clr-muted);line-height:1.7;margin:0}
.hiw-tip{margin-top:.85rem;background:var(--clr-primary-2);color:var(--clr-primary);font-size:.8rem;padding:.5rem .75rem;border-radius:var(--radius-sm);line-height:1.5}
.hiw-tip a{color:var(--clr-primary);font-weight:600}
.advice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}
.advice-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.25rem}
.advice-icon{width:36px;height:36px;border-radius:50%;background:var(--clr-primary-l);color:var(--clr-primary);font-size:1rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:.75rem}
.advice-card h4{margin-bottom:.4rem;font-size:.9rem}
.advice-card p{font-size:.82rem;color:var(--clr-muted);margin:0;line-height:1.6}

/* FAQ */
.faq-section{margin-bottom:2.5rem}
.faq-section-title{font-size:1.15rem;font-weight:700;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--clr-border)}
.faq-cta{text-align:center;margin-top:3rem;padding:2rem;background:var(--clr-bg-2);border-radius:var(--radius-lg)}
.faq-cta h3{margin-bottom:.4rem}
.faq-cta p{font-size:.9rem;color:var(--clr-muted);margin:0}

/* ====================================================
   PAGES LEGALES + SECURITE
   ==================================================== */

/* Legal pages */
.legal-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:2px solid var(--clr-border)}
.legal-updated{font-size:.82rem;color:var(--clr-muted);margin-bottom:.75rem}
.legal-header h1{margin-bottom:.5rem}
.legal-toc{background:var(--clr-bg-2);border-radius:var(--radius-md);padding:1.25rem 1.5rem;margin-bottom:2.5rem}
.legal-toc h4{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--clr-muted);margin-bottom:.6rem}
.legal-toc ol{padding-left:1.25rem;display:flex;flex-direction:column;gap:.3rem}
.legal-toc a{font-size:.875rem;color:var(--clr-primary)}
.legal-toc a:hover{text-decoration:underline}
.legal-content section{margin-bottom:2.5rem}
.legal-content h2{font-size:1.2rem;margin-bottom:.85rem;padding-top:1rem;color:var(--clr-text)}
.legal-content h3{font-size:1rem;font-weight:600;margin-top:1.25rem;margin-bottom:.5rem}
.legal-content p{margin-bottom:.75rem;font-size:.9rem;line-height:1.75}
.legal-content ul{padding-left:1.5rem;list-style:disc;margin-bottom:.75rem}
.legal-content ul li{font-size:.875rem;color:var(--clr-muted);line-height:1.7;margin-bottom:.3rem}
.legal-footer{display:flex;gap:.75rem;flex-wrap:wrap;padding-top:2rem;margin-top:2rem;border-top:1px solid var(--clr-border)}
.privacy-table{width:100%;border-collapse:collapse;font-size:.85rem;margin-bottom:1rem}
.privacy-table th{background:var(--clr-bg-2);text-align:left;padding:.6rem .9rem;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;color:var(--clr-muted)}
.privacy-table td{padding:.65rem .9rem;border-bottom:1px solid var(--clr-border);color:var(--clr-muted)}
.privacy-table tr:last-child td{border-bottom:none}
.privacy-note{background:var(--clr-primary-2);border-left:3px solid var(--clr-primary);padding:.65rem .9rem;border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:.85rem;color:var(--clr-muted)}
.rights-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}
.right-badge{background:var(--clr-primary-l);color:var(--clr-primary);font-size:.78rem;font-weight:600;padding:.25rem .65rem;border-radius:99px}

/* Page Sécurité */
.security-hero{background:linear-gradient(135deg,#0f172a,#1e3a5f);color:#fff;padding:4rem 0 3rem;text-align:center}
.security-hero-icon{font-size:3rem;margin-bottom:1rem}
.security-hero h1{color:#fff;margin-bottom:.75rem}
.security-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem}
.security-feature{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.5rem}
.sf-icon{font-size:2rem;margin-bottom:.75rem;display:block}
.security-feature h3{font-size:.95rem;font-weight:700;margin-bottom:.4rem}
.security-feature p{font-size:.85rem;color:var(--clr-muted);margin:0;line-height:1.6}
.security-tips{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem}
@media(max-width:700px){.security-tips{grid-template-columns:1fr}}
.security-tip{border-radius:var(--radius-lg);padding:1.5rem;border:1.5px solid var(--clr-border)}
.security-tip-do{background:#f0fdf4;border-color:#86efac}
.security-tip-dont{background:#fff7ed;border-color:#fed7aa}
.tip-header{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem}
.tip-icon{font-size:1.25rem}
.tip-header h3{font-size:.95rem;font-weight:700;margin:0}
.security-tip ul{padding-left:1.25rem;list-style:disc}
.security-tip ul li{font-size:.875rem;color:var(--clr-muted);margin-bottom:.5rem;line-height:1.6}
.security-alert-box{background:#fef2f2;border:2px solid #fca5a5;border-radius:var(--radius-lg);padding:1.5rem}
.security-alert-box h3{color:#dc2626;margin-bottom:1rem}
.alert-signals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem;margin-bottom:.5rem}
.alert-signal{background:#fff;border:1px solid #fca5a5;border-radius:var(--radius-sm);padding:.45rem .75rem;font-size:.82rem;color:#dc2626}
.report-steps{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}
.report-step{display:flex;gap:1rem;align-items:flex-start;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-md);padding:1.1rem}
.report-step-num{width:32px;height:32px;border-radius:50%;background:var(--clr-primary);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.875rem}
.report-step h4{font-size:.9rem;font-weight:700;margin-bottom:.25rem}
.report-step p{font-size:.85rem;color:var(--clr-muted);margin:0;line-height:1.6}
.report-commitment{background:var(--clr-primary-2);border:1px solid #5eead4;border-radius:var(--radius-lg);padding:1.5rem}
.report-commitment h3{font-size:.95rem;font-weight:700;margin-bottom:.75rem;color:var(--clr-primary)}
.report-commitment ul{padding-left:1.25rem;list-style:disc}
.report-commitment ul li{font-size:.875rem;color:var(--clr-muted);margin-bottom:.4rem;line-height:1.6}
.data-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}
.data-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.25rem;text-align:center}
.data-card-icon{font-size:2rem;margin-bottom:.6rem;display:block}
.data-card h4{font-size:.875rem;font-weight:700;margin-bottom:.4rem}
.data-card p{font-size:.8rem;color:var(--clr-muted);margin:0;line-height:1.6}
.data-rights{background:var(--clr-bg-2);border-radius:var(--radius-lg);padding:1.5rem}
.data-rights h3{font-size:.95rem;font-weight:700;margin-bottom:.75rem}

/* =====================================================
   FOOTER ÉTENDU
   ===================================================== */
.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr !important}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr !important}}
@media(max-width:540px){.footer-grid{grid-template-columns:1fr !important}}
.footer-social{display:flex;gap:.5rem;margin-top:1rem}
.footer-social-link{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.1);color:#94a3b8;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:background .15s,color .15s}
.footer-social-link:hover{background:var(--clr-primary);color:#fff}

/* =====================================================
   NOUVELLE PAGE D'ACCUEIL (accueil.php)
   ===================================================== */

/* Hero homepage */
.home-hero{background:linear-gradient(135deg,#0a4d45 0%,#0f766e 45%,#0284c7 100%);color:#fff;padding:5rem 0 4rem;position:relative;overflow:hidden;min-height:90vh;display:flex;align-items:center}
.home-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 70% 40%,rgba(255,255,255,.06),transparent);pointer-events:none}
.home-hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
@media(max-width:900px){.home-hero-inner{grid-template-columns:1fr;gap:3rem}}
.home-hero-label{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);font-size:.8rem;font-weight:600;padding:.35rem .85rem;border-radius:99px;margin-bottom:1.5rem;backdrop-filter:blur(8px)}
.home-hero-title{color:#fff;font-size:clamp(2rem,4.5vw,3.2rem);margin-bottom:1.25rem;line-height:1.1}
.text-gradient-white{background:linear-gradient(135deg,#fff,#a5f3e0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.home-hero-lead{color:rgba(255,255,255,.82);font-size:1.1rem;line-height:1.7;margin-bottom:2rem;max-width:520px}
.home-hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}
.btn-white{background:#fff;color:var(--clr-primary);font-weight:700}
.btn-white:hover{background:#f0fdfa}
.btn-outline-white{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.6);font-weight:700}
.btn-outline-white:hover{background:rgba(255,255,255,.15);border-color:#fff}
.btn-ghost-white{background:transparent;color:rgba(255,255,255,.85)}
.btn-ghost-white:hover{background:rgba(255,255,255,.1)}
.ml-3{margin-left:.75rem}
.home-hero-trust{display:flex;flex-wrap:wrap;gap:.75rem}
.home-hero-trust span{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;color:rgba(255,255,255,.85);background:rgba(255,255,255,.12);padding:.3rem .75rem;border-radius:99px;backdrop-filter:blur(4px)}

/* Hero card visual */
.home-hero-visual{position:relative}
@media(max-width:900px){.home-hero-visual{display:none}}
.home-hero-card{background:#fff;border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-xl);position:relative;z-index:1}
.hhc-header{display:flex;align-items:center;gap:.85rem;margin-bottom:.85rem}
.hhc-avatar{width:44px;height:44px;border-radius:50%;background:var(--clr-primary);color:#fff;font-weight:800;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hhc-header strong{font-size:.95rem;font-weight:700;color:var(--clr-text);display:block}
.hhc-job{font-size:.78rem;color:var(--clr-muted)}
.hhc-stars{display:flex;align-items:center;gap:.35rem;font-size:.95rem;color:var(--clr-gold);margin-bottom:.75rem}
.hhc-stars span{font-size:.8rem;color:var(--clr-muted);font-weight:500}
.hhc-bio{font-size:.85rem;color:var(--clr-muted);line-height:1.6;margin-bottom:.85rem}
.hhc-tags{display:flex;flex-wrap:wrap;gap:.35rem}
.hhc-tags span{background:var(--clr-primary-l);color:var(--clr-primary);font-size:.72rem;font-weight:600;padding:.2rem .6rem;border-radius:99px}
.home-hero-float{position:absolute;background:#fff;border-radius:var(--radius-md);padding:.5rem 1rem;font-size:.8rem;font-weight:600;color:var(--clr-text);box-shadow:var(--shadow-md);display:flex;align-items:center;gap:.4rem;z-index:2}
.home-hero-float i{color:var(--clr-primary)}
.home-hero-float-1{top:-1.25rem;left:-1.5rem}
.home-hero-float-2{bottom:-1rem;right:-1rem}

/* Chiffres clés */
.home-numbers{background:linear-gradient(135deg,var(--clr-primary),#0284c7);padding:2.5rem 0}
.home-numbers-grid{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap}
.home-number-item{text-align:center;padding:1rem 2.5rem;flex:1;min-width:140px}
.home-number-value{font-size:clamp(2rem,4vw,3rem);font-weight:900;color:#fff;line-height:1;margin-bottom:.35rem}
.home-number-label{font-size:.85rem;color:rgba(255,255,255,.75);line-height:1.5}
.home-number-divider{width:1px;height:60px;background:rgba(255,255,255,.25)}
@media(max-width:640px){.home-number-divider{display:none}.home-number-item{min-width:50%;padding:.75rem 1rem}}

/* Pour qui */
.pour-qui-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
@media(max-width:767px){.pour-qui-grid{grid-template-columns:1fr}}
.pour-qui-card{background:var(--clr-bg);border:2px solid var(--clr-border);border-radius:var(--radius-xl);padding:2.5rem;display:flex;flex-direction:column}
.pour-qui-client{border-color:var(--clr-primary);background:linear-gradient(to bottom right,#f0fdfa,#fff)}
.pour-qui-provider{border-color:var(--clr-gold);background:linear-gradient(to bottom right,#fffbeb,#fff)}
.pq-icon{font-size:2.5rem;width:60px;height:60px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.pour-qui-client .pq-icon{background:var(--clr-primary-l);color:var(--clr-primary)}
.pour-qui-provider .pq-icon{background:var(--clr-gold-l);color:var(--clr-gold)}
.pour-qui-card h3{font-size:1.3rem;margin-bottom:.75rem}
.pour-qui-card>p{color:var(--clr-muted);line-height:1.7;margin-bottom:1.25rem}
.pq-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:auto}
.pq-list li{display:flex;align-items:center;gap:.6rem;font-size:.9rem;color:var(--clr-text)}
.pq-list i{color:var(--clr-primary);font-size:1rem;flex-shrink:0}
.pour-qui-provider .pq-list i{color:var(--clr-gold)}

/* Mission */
.home-mission{background:var(--clr-bg)}
.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
@media(max-width:767px){.mission-grid{grid-template-columns:1fr;gap:2rem}}
.mission-pill{display:inline-block;background:var(--clr-primary-l);color:var(--clr-primary);font-size:.78rem;font-weight:700;padding:.3rem .85rem;border-radius:99px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:1rem}
.mission-text h2{margin-bottom:1rem}
.mission-text p{margin-bottom:1rem}
.mission-values{display:flex;flex-direction:column;gap:1.25rem}
.mission-value{display:flex;align-items:flex-start;gap:1rem;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.1rem 1.25rem}
.mv-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--clr-primary-l);color:var(--clr-primary);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.mv-icon-gold{background:var(--clr-gold-l);color:var(--clr-gold)}
.mv-icon-blue{background:#dbeafe;color:#1d4ed8}
.mv-icon-green{background:#dcfce7;color:#16a34a}
.mission-value strong{display:block;font-size:.9rem;font-weight:700;color:var(--clr-text);margin-bottom:.25rem}
.mission-value p{font-size:.82rem;color:var(--clr-muted);margin:0;line-height:1.6}

/* Steps homepage */
.home-steps{display:flex;align-items:flex-start;gap:1rem;flex-wrap:wrap;justify-content:center}
.home-step{flex:1;min-width:200px;max-width:280px;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:2rem 1.5rem;text-align:center;position:relative}
.home-step-num{position:absolute;top:-1rem;left:50%;transform:translateX(-50%);width:2rem;height:2rem;border-radius:50%;background:var(--clr-primary);color:#fff;font-weight:800;font-size:.875rem;display:flex;align-items:center;justify-content:center}
.home-step-icon{font-size:2.5rem;margin-bottom:.75rem;color:var(--clr-primary);display:block}
.home-step h3{margin-bottom:.5rem}
.home-step p{font-size:.875rem;color:var(--clr-muted);line-height:1.6;margin:0}
.home-step-arrow{font-size:1.5rem;color:var(--clr-border);display:flex;align-items:center;padding-top:1rem;flex-shrink:0}
@media(max-width:640px){.home-step-arrow{transform:rotate(90deg)}}

/* Testimonials */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.testimonial-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-xl);padding:1.75rem;display:flex;flex-direction:column;gap:1rem}
.testi-stars{color:var(--clr-gold);font-size:1rem;display:flex;gap:.2rem}
.testimonial-card p{font-size:.9rem;color:var(--clr-muted);line-height:1.7;flex:1;font-style:italic;margin:0}
.testi-author{display:flex;align-items:center;gap:.75rem;padding-top:.75rem;border-top:1px solid var(--clr-border)}
.testi-avatar{width:40px;height:40px;border-radius:50%;background:var(--clr-primary);color:#fff;font-weight:700;font-size:.9rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.testi-author strong{display:block;font-size:.875rem;font-weight:700;color:var(--clr-text)}
.testi-author span{font-size:.75rem;color:var(--clr-muted)}

/* CTA double final */
.home-final-cta{background:linear-gradient(135deg,#0f172a,#1e3a5f);padding:5rem 0}
.home-final-cta-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:0;align-items:center}
@media(max-width:767px){.home-final-cta-grid{grid-template-columns:1fr;gap:2rem}}
.hfcta-block{text-align:center;padding:2rem 3rem;color:#fff}
.hfcta-icon{font-size:3rem;margin-bottom:1.25rem;opacity:.9;display:block}
.hfcta-block h3{font-size:1.4rem;font-weight:700;color:#fff;margin-bottom:.75rem}
.hfcta-block p{color:rgba(255,255,255,.7);font-size:.95rem;margin-bottom:1.5rem;max-width:340px;margin-inline:auto}
.hfcta-divider{width:1px;height:200px;background:rgba(255,255,255,.15);align-self:center}
@media(max-width:767px){.hfcta-divider{width:100%;height:1px}}

/* =====================================================
   PAGE À PROPOS
   ===================================================== */
.about-hero{background:linear-gradient(135deg,#0f172a,#1e3a5f);color:#fff;padding:5rem 0 4rem;text-align:center}
.about-hero-content{max-width:700px;margin-inline:auto}
.about-hero-pill{display:inline-block;background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);font-size:.8rem;font-weight:700;padding:.35rem .9rem;border-radius:99px;margin-bottom:1.25rem;letter-spacing:.04em;text-transform:uppercase;backdrop-filter:blur(8px)}
.about-hero h1{color:#fff;margin-bottom:1rem}
.about-story{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
@media(max-width:767px){.about-story{grid-template-columns:1fr;gap:2rem}}
.about-story-text h2{margin-bottom:1.25rem}
.about-story-text p{margin-bottom:1rem;color:var(--clr-muted);line-height:1.8}
.about-story-visual{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.about-story-stat{background:var(--clr-surface);border:2px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.5rem;text-align:center}
.ass-value{font-size:2.5rem;font-weight:900;color:var(--clr-primary);line-height:1;margin-bottom:.4rem}
.ass-label{font-size:.8rem;color:var(--clr-muted);line-height:1.4}
.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem}
.value-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-xl);padding:1.75rem;transition:box-shadow .2s,transform .15s}
.value-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.value-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:1rem}
.value-card h3{font-size:1rem;font-weight:700;margin-bottom:.5rem}
.value-card p{font-size:.875rem;color:var(--clr-muted);line-height:1.6;margin:0}
.about-engagement{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-xl);padding:2.5rem}
.about-engagement-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}
.about-engagement-header i{font-size:2rem;color:var(--clr-gold)}
.about-engagement-header h2{margin:0}
.about-engagement-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
@media(max-width:640px){.about-engagement-grid{grid-template-columns:1fr}}
.aeg-item{display:flex;align-items:flex-start;gap:1rem}
.aeg-item>i{width:28px;height:28px;border-radius:50%;background:var(--clr-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;margin-top:.1rem}
.aeg-item strong{display:block;font-size:.9rem;font-weight:700;color:var(--clr-text);margin-bottom:.35rem}
.aeg-item p{font-size:.85rem;color:var(--clr-muted);line-height:1.6;margin:0}
.about-cta{background:linear-gradient(135deg,var(--clr-primary),#0284c7);padding:5rem 0;text-align:center}
.about-cta-inner{max-width:640px;margin-inline:auto}
.about-cta h2{color:#fff;margin-bottom:.75rem}
.about-cta p{color:rgba(255,255,255,.8);font-size:1rem;margin-bottom:2rem;line-height:1.7}
.about-cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* =====================================================
   SECTION ÉQUIPE DIRIGEANTE
   ===================================================== */

/* Grid - 1 carte par ligne (layout horizontal) */
.team-grid{display:flex;flex-direction:column;gap:1.75rem;margin-bottom:2.5rem}

/* Carte - image gauche / contenu droite */
.team-card{display:grid;grid-template-columns:280px 1fr;gap:0;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-xl);overflow:hidden;transition:box-shadow .25s,transform .2s,border-color .25s}
.team-card:hover{box-shadow:0 12px 48px rgba(21,101,192,.12);transform:translateY(-3px);border-color:var(--clr-primary)}

/* Photo - alignée depuis le haut du visage */
.team-card-photo-wrap{position:relative;overflow:hidden;background:linear-gradient(160deg,#0D47A1,#1565C0 50%,#43A047)}
.team-card-photo{width:100%;height:100%;min-height:340px;object-fit:cover;object-position:top center;display:block;transition:transform .4s ease}
.team-card:hover .team-card-photo{transform:scale(1.04)}

/* Badge rôle sur la photo */
.team-card-role-badge{position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);white-space:nowrap;background:linear-gradient(135deg,var(--brand-blue),var(--brand-green));color:#fff;font-size:.72rem;font-weight:700;padding:.4rem 1rem;border-radius:99px;letter-spacing:.06em;text-transform:uppercase;display:inline-flex;align-items:center;gap:.35rem;box-shadow:0 3px 14px rgba(0,0,0,.3)}

/* Corps - colonne droite */
.team-card-body{padding:2rem 2.25rem;display:flex;flex-direction:column;gap:.85rem;justify-content:center}

/* Pill catégorie (en-tête) */
.team-card-category{display:inline-flex;align-items:center;gap:.4rem;background:var(--clr-primary-l);color:var(--clr-primary);border:1px solid var(--clr-primary);font-size:.68rem;font-weight:800;padding:.3rem .85rem;border-radius:99px;letter-spacing:.1em;text-transform:uppercase;align-self:flex-start}

/* Nom */
.team-card-name{font-size:1.55rem;font-weight:900;color:var(--clr-text);letter-spacing:.04em;text-transform:uppercase;margin:0;line-height:1.1}

/* Fonction + séparateur dégradé */
.team-card-role-wrap{display:flex;flex-direction:column;gap:.5rem}
.team-card-role-title{font-size:.95rem;font-weight:600;color:var(--clr-primary);margin:0}
.team-card-separator{display:block;width:52px;height:3px;border-radius:2px;background:linear-gradient(90deg,var(--brand-blue),var(--brand-green))}

/* Description */
.team-card-desc{font-size:.875rem;color:var(--clr-muted);line-height:1.75;margin:0}

/* Citation inline */
.team-card-quote{margin:0;font-size:.83rem;font-style:italic;color:var(--clr-muted);line-height:1.65;padding-left:.85rem;border-left:3px solid var(--clr-primary);opacity:.85}

/* Tags badge (points clés) */
.team-card-tags{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.45rem}
.team-card-tags li{display:inline-flex;align-items:center;gap:.3rem;background:var(--clr-bg);border:1.5px solid var(--clr-border);border-radius:99px;padding:.28rem .7rem;font-size:.78rem;font-weight:500;color:var(--clr-text);transition:border-color .15s,color .15s}
.team-card-tags li:hover{border-color:var(--clr-primary);color:var(--clr-primary)}
.team-card-tags li i{color:var(--clr-primary);font-size:.78rem;flex-shrink:0}

/* CTA bas de section */
.team-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}

/* ── About hero CTA ──────────────────────────────────── */
.about-hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}

/* ── About stats strip ──────────────────────────────── */
.about-stats-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:1.25rem}
.ass-card{background:var(--clr-surface);border:2px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.5rem;text-align:center;transition:border-color .2s,transform .15s}
.ass-card:hover{border-color:var(--clr-primary);transform:translateY(-2px)}

/* ── About mid CTA ───────────────────────────────────── */
.about-mid-cta{background:var(--clr-primary-l);border:1.5px solid var(--clr-primary);border-radius:var(--radius-xl);padding:2.75rem 2rem;text-align:center}
.about-mid-cta h3{color:var(--clr-primary);font-size:1.3rem;margin-bottom:.6rem}
.about-mid-cta p{color:var(--clr-muted);margin-bottom:1.75rem;max-width:520px;margin-inline:auto}
.about-mid-cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ── About problem ───────────────────────────────────── */
.about-problem-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
@media(max-width:640px){.about-problem-grid{grid-template-columns:1fr}}
.ap-problem-card{border-radius:var(--radius-xl);padding:2rem}
.ap-problem-card.for-candidate{background:#eff6ff;border:1px solid #bfdbfe}
.ap-problem-card.for-recruiter{background:#f0fdf4;border:1px solid #bbf7d0}
.ap-problem-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:1rem}
.ap-problem-card h3{font-size:1.05rem;font-weight:700;margin-bottom:.8rem}
.ap-problem-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.55rem}
.ap-problem-list li{display:flex;align-items:flex-start;gap:.6rem;font-size:.875rem;color:var(--clr-muted);line-height:1.5}
.ap-problem-list li::before{content:"✕";color:var(--clr-danger);font-weight:700;flex-shrink:0;margin-top:.05rem}

/* ── About solution ──────────────────────────────────── */
.about-solution-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem}
.ap-solution-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-xl);padding:1.75rem;text-align:center;transition:box-shadow .2s,transform .15s}
.ap-solution-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.ap-solution-icon{width:52px;height:52px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin:0 auto 1rem}
.ap-solution-card h3{font-size:.95rem;font-weight:700;margin-bottom:.5rem}
.ap-solution-card p{font-size:.85rem;color:var(--clr-muted);line-height:1.6;margin:0}

/* ── About differentiation ───────────────────────────── */
.ap-diff-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.25rem}
.ap-diff-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-xl);padding:1.75rem;transition:box-shadow .2s,transform .15s}
.ap-diff-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.ap-diff-num{display:block;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--clr-primary);margin-bottom:.6rem}
.ap-diff-icon{font-size:1.75rem;margin-bottom:.65rem;display:block}
.ap-diff-card h3{font-size:1rem;font-weight:700;margin-bottom:.5rem}
.ap-diff-card p{font-size:.875rem;color:var(--clr-muted);line-height:1.6;margin:0}

/* =====================================================
   PAGE CONTACT
   ===================================================== */
.contact-hero{background:linear-gradient(135deg,#0f766e,#0284c7);color:#fff;padding:4.5rem 0 3.5rem;text-align:center}
.contact-hero-content{max-width:600px;margin-inline:auto}
.contact-hero h1{color:#fff;margin-bottom:1rem}
.contact-layout{display:grid;grid-template-columns:1fr 400px;gap:3rem;align-items:start}
@media(max-width:900px){.contact-layout{grid-template-columns:1fr;gap:2rem}}
.contact-form-panel h2{font-size:1.5rem;font-weight:800;margin-bottom:.5rem}
.contact-form{display:flex;flex-direction:column;gap:.1rem;margin-top:1.5rem}
.contact-form-note{font-size:.78rem;color:var(--clr-subtle);text-align:center;margin-top:1rem;display:flex;align-items:center;justify-content:center;gap:.4rem}
.contact-success{background:#f0fdf4;border:2px solid #86efac;border-radius:var(--radius-lg);padding:2rem;text-align:center}
.contact-success i{font-size:2.5rem;color:var(--clr-success);display:block;margin-bottom:.75rem}
.contact-success strong{display:block;font-size:1.1rem;font-weight:700;margin-bottom:.5rem}
.contact-success p{font-size:.9rem;color:var(--clr-muted);margin:0}
.contact-info-panel{display:flex;flex-direction:column;gap:1.25rem}
.contact-info-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.5rem}
.contact-info-card h3{font-size:1rem;font-weight:700;margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem}
.contact-info-item{display:flex;align-items:flex-start;gap:.85rem;padding:.75rem 0;border-bottom:1px solid var(--clr-border)}
.contact-info-item:last-child{border-bottom:none}
.cii-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--clr-primary-l);color:var(--clr-primary);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.contact-info-item strong{display:block;font-size:.85rem;font-weight:700;color:var(--clr-text);margin-bottom:.15rem}
.contact-info-item a,.contact-info-item span{font-size:.875rem;color:var(--clr-muted)}
.contact-info-item a{color:var(--clr-primary)}
.contact-faq-card{background:var(--clr-primary-2);border-color:#5eead4}
.contact-faq-card h3{color:var(--clr-primary)}
.contact-faq-card p{font-size:.875rem;color:var(--clr-muted)}
.contact-report-card{background:#fff7ed;border-color:#fed7aa}
.contact-report-card h3{color:#92400e}
.contact-report-card p{font-size:.875rem;color:var(--clr-muted);margin-bottom:.5rem}
.contact-report-link{font-size:.95rem;color:var(--clr-primary);font-weight:700}
.contact-report-link:hover{text-decoration:underline}

/* =====================================================
   AUTH - LAYOUT SPLIT
   ===================================================== */
.auth-split-page{display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - var(--header-h))}

.auth-split-left{background:linear-gradient(145deg,#0a4d45,#0f766e 60%,#0284c7);color:#fff;padding:3rem 2.5rem;display:flex;flex-direction:column;gap:2rem;position:relative;overflow:hidden}
.auth-split-left::before{content:"";position:absolute;top:-40%;right:-20%;width:500px;height:500px;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none}

.auth-split-logo{font-size:1.4rem;font-weight:800;color:#fff;letter-spacing:-.02em}
.auth-split-logo span{color:rgba(255,255,255,.7)}

.auth-split-pitch h2{font-size:1.5rem;font-weight:800;color:#fff;margin-bottom:.6rem}
.auth-split-pitch p{color:rgba(255,255,255,.78);font-size:.95rem;line-height:1.7;margin:0}

.auth-split-benefits{list-style:none;display:flex;flex-direction:column;gap:1rem;margin:0;padding:0}
.auth-split-benefits li{display:flex;align-items:flex-start;gap:.85rem}
.asb-icon{width:36px;height:36px;border-radius:var(--radius-md);background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.auth-split-benefits strong{display:block;font-size:.875rem;font-weight:700;color:#fff;margin-bottom:.1rem}
.auth-split-benefits span{font-size:.8rem;color:rgba(255,255,255,.7);line-height:1.4}

.auth-split-stats{display:flex;gap:0;margin-top:auto;background:rgba(255,255,255,.1);border-radius:var(--radius-lg);overflow:hidden}
.auth-split-stat{flex:1;text-align:center;padding:.85rem .5rem;border-right:1px solid rgba(255,255,255,.15)}
.auth-split-stat:last-child{border-right:none}
.auth-split-stat strong{display:block;font-size:1.4rem;font-weight:800;color:#fff;line-height:1}
.auth-split-stat span{font-size:.72rem;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.05em}

.auth-split-right{background:var(--clr-bg);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;min-height:calc(100vh - var(--header-h))}
.auth-split-form-wrap{width:100%;max-width:420px}
.auth-split-form-wide{max-width:520px}
/* Le header mobile est masqué par défaut (desktop) */
.auth-mobile-header{display:none}
.auth-split-form-header{margin-bottom:1.75rem}
.auth-split-form-header h1{font-size:1.75rem;font-weight:800;margin-bottom:.3rem}
.auth-split-form-header p{color:var(--clr-muted);font-size:.9rem;margin:0}

/* Champs avec icône */
.input-icon-wrap{position:relative}
.input-icon{position:absolute;left:.85rem;top:50%;transform:translateY(-50%);color:var(--clr-subtle);font-size:1rem;pointer-events:none}
.form-control-icon{padding-left:2.5rem}

.form-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.35rem}
.form-label-link{font-size:.8rem;color:var(--clr-primary);font-weight:500}
.form-label-link:hover{text-decoration:underline}

.auth-split-divider{position:relative;text-align:center;margin:1.25rem 0}
.auth-split-divider::before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--clr-border)}
.auth-split-divider span{position:relative;background:var(--clr-bg);padding:0 .75rem;font-size:.8rem;color:var(--clr-subtle)}

.auth-split-legal{font-size:.72rem;color:var(--clr-subtle);text-align:center;margin-top:1.25rem;line-height:1.5}
.auth-split-legal a{color:var(--clr-muted)}
.auth-split-legal a:hover{text-decoration:underline}

/* Register - deux rôles dans le panneau gauche */
.auth-reg-roles{display:flex;flex-direction:column;gap:1rem}
.auth-reg-role{display:flex;align-items:flex-start;gap:.85rem;background:rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:1rem 1.1rem}
.auth-reg-role-provider{background:rgba(217,119,6,.2)}
.arr-icon{width:40px;height:40px;border-radius:var(--radius-md);background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;color:#fff}
.auth-reg-role strong{display:block;font-size:.875rem;font-weight:700;color:#fff;margin-bottom:.4rem}
.auth-reg-role ul{list-style:none;display:flex;flex-direction:column;gap:.25rem}
.auth-reg-role ul li{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:rgba(255,255,255,.8)}
.auth-reg-role ul i{color:rgba(255,255,255,.9);font-size:.85rem}

/* =====================================================
   SEARCH-FIRST HERO (/trouver)
   ===================================================== */
.sf-hero{background:linear-gradient(145deg,#0a4d45 0%,#0f766e 45%,#0284c7 100%);color:#fff;padding:5rem 0 4rem;position:relative;overflow:hidden;text-align:center}
.sf-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 70% at 50% 0%,rgba(255,255,255,.06),transparent);pointer-events:none}
.sf-hero-label{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);font-size:.78rem;font-weight:600;padding:.3rem .85rem;border-radius:99px;margin-bottom:1.5rem;backdrop-filter:blur(8px)}
.sf-hero-title{color:#fff;font-size:clamp(1.75rem,4vw,3rem);font-weight:800;line-height:1.1;margin-bottom:1rem;letter-spacing:-.03em}
.sf-hero-sub{color:rgba(255,255,255,.8);font-size:1.05rem;line-height:1.7;max-width:560px;margin:0 auto 2.5rem}

/* Barre de recherche dominante */
.sf-search-wrap{max-width:800px;margin:0 auto 1.5rem}
.sf-search-form{
  display:flex;align-items:stretch;
  background:#fff;border-radius:var(--radius-xl);
  box-shadow:0 8px 40px rgba(0,0,0,.22);
  overflow:hidden;height:80px
}
.sf-search-field{
  flex:1;display:flex;flex-direction:column;justify-content:center;
  position:relative;min-width:0;padding:0 1rem 0 3.2rem;
  border-right:1px solid var(--clr-border);
}
.sf-field-icon{
  position:absolute;left:1rem;top:50%;transform:translateY(-50%);
  color:var(--clr-subtle);font-size:1.1rem;pointer-events:none;z-index:1
}
.sf-field-label{
  display:block;order:-1;font-size:.68rem;font-weight:700;
  color:var(--clr-muted);text-transform:uppercase;letter-spacing:.06em;
  margin-bottom:.2rem;line-height:1
}
.sf-search-field input{
  width:100%;border:none;outline:none;
  font-size:1rem;font-weight:500;color:var(--clr-text);
  background:transparent;padding:0;line-height:1.3
}
.sf-search-field input::placeholder{color:var(--clr-subtle);font-weight:400}
.sf-search-divider{display:none}
.sf-search-btn{
  height:auto;padding:0 2.25rem;
  background:var(--clr-primary);color:#fff;border:none;
  font-size:1rem;font-weight:700;cursor:pointer;
  display:flex;align-items:center;gap:.5rem;
  flex-shrink:0;transition:background .15s;white-space:nowrap
}
.sf-search-btn:hover{background:var(--clr-primary-d)}
@media(max-width:600px){
  .sf-search-form{
    flex-direction:column;height:auto;
    border-radius:var(--radius-lg);padding:.5rem;gap:.4rem
  }
  .sf-search-field{
    border-right:none;border:1.5px solid var(--clr-border);
    border-radius:var(--radius-md);background:#f8fafc;
    min-width:100%;padding:.75rem 1rem .75rem 3rem;height:60px
  }
  .sf-field-icon{top:50%;transform:translateY(-50%)}
  .sf-search-btn{
    width:100%;height:54px;border-radius:var(--radius-md);
    justify-content:center;font-size:1rem
  }
}

/* Recherches populaires */
.sf-popular{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:1rem}
.sf-popular-label{font-size:.8rem;color:rgba(255,255,255,.7);font-weight:500;flex-shrink:0}
.sf-popular-chips{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center}
.sf-chip{background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);font-size:.78rem;font-weight:500;padding:.3rem .8rem;border-radius:99px;border:1px solid rgba(255,255,255,.2);cursor:pointer;transition:background .15s;backdrop-filter:blur(4px);text-decoration:none}
.sf-chip:hover{background:rgba(255,255,255,.28)}

/* Raccourcis par intention */
.sf-intents{padding:2rem 0;background:var(--clr-surface)}
.sf-intents-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
@media(max-width:900px){.sf-intents-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.sf-intents-grid{grid-template-columns:1fr}}
.sf-intent-card{display:flex;align-items:center;gap:.85rem;padding:1rem 1.25rem;border-radius:var(--radius-lg);border:1.5px solid var(--clr-border);background:var(--clr-bg);text-decoration:none;color:var(--clr-text);transition:all .2s;cursor:pointer}
.sf-intent-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:currentColor}
.sf-intent-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.sf-intent-premium{color:var(--clr-gold)}.sf-intent-premium .sf-intent-icon{background:#fef3c7;color:var(--clr-gold)}
.sf-intent-top{color:var(--clr-primary)}.sf-intent-top .sf-intent-icon{background:var(--clr-primary-l);color:var(--clr-primary)}
.sf-intent-new{color:#0284c7}.sf-intent-new .sf-intent-icon{background:#dbeafe;color:#0284c7}
.sf-intent-local{color:#16a34a}.sf-intent-local .sf-intent-icon{background:#dcfce7;color:#16a34a}
.sf-intent-body{flex:1;min-width:0}
.sf-intent-body strong{display:block;font-size:.875rem;font-weight:700;margin-bottom:.1rem;color:var(--clr-text)}
.sf-intent-body span{font-size:.75rem;color:var(--clr-muted)}
.sf-intent-arrow{font-size:1rem;opacity:.5;flex-shrink:0}

/* Catégories domaines */
.sf-domain-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.85rem}
@media(max-width:900px){.sf-domain-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.sf-domain-grid{grid-template-columns:repeat(2,1fr)}}
.sf-domain-card{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1.1rem .75rem;background:var(--clr-surface);border:1.5px solid var(--clr-border);border-radius:var(--radius-lg);text-align:center;text-decoration:none;color:var(--clr-text);transition:all .2s}
.sf-domain-card:hover{border-color:var(--clr-primary);box-shadow:var(--shadow-md);transform:translateY(-2px);color:var(--clr-primary)}
.sf-domain-icon{width:44px;height:44px;border-radius:var(--radius-md);background:var(--clr-primary-l);color:var(--clr-primary);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}
.sf-domain-name{font-size:.82rem;font-weight:700;line-height:1.3}
.sf-domain-count{font-size:.72rem;color:var(--clr-muted)}

/* Steps SF */
.sf-steps{display:flex;align-items:flex-start;justify-content:center;gap:.5rem;flex-wrap:wrap}
.sf-step{flex:1;min-width:200px;max-width:260px;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.75rem 1.25rem;text-align:center;position:relative}
.sf-step-badge{position:absolute;top:-1rem;left:50%;transform:translateX(-50%);width:2rem;height:2rem;border-radius:50%;background:var(--clr-primary);color:#fff;font-weight:800;font-size:.875rem;display:flex;align-items:center;justify-content:center}
.sf-step-icon{font-size:2.25rem;color:var(--clr-primary);margin-bottom:.75rem;display:block}
.sf-step h3{font-size:1rem;font-weight:700;margin-bottom:.5rem}
.sf-step p{font-size:.84rem;color:var(--clr-muted);line-height:1.6;margin:0}
.sf-step-connector{font-size:1.5rem;color:var(--clr-border);padding-top:1.5rem;flex-shrink:0}
@media(max-width:640px){.sf-step-connector{transform:rotate(90deg);padding:0}}

/* =====================================================
   PAGE RÉSULTATS - NOUVEAU STYLE
   ===================================================== */

/* Barre recherche compacte */
.rs-search-bar{background:var(--clr-primary);padding:.75rem 0;position:sticky;top:64px;z-index:90;box-shadow:var(--shadow-sm)}
.rs-search-form{display:flex;align-items:center;background:rgba(255,255,255,.15);border-radius:var(--radius-lg);overflow:hidden;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);height:46px}
.rs-field{flex:1;display:flex;align-items:center;gap:.5rem;padding:0 .85rem;min-width:0}
.rs-field i{color:rgba(255,255,255,.7);font-size:.95rem;flex-shrink:0}
.rs-field input{background:transparent;border:none;outline:none;width:100%;height:100%;font-size:.875rem;color:#fff}
.rs-field input::placeholder{color:rgba(255,255,255,.6)}
.rs-field-divider{width:1px;height:26px;background:rgba(255,255,255,.25);flex-shrink:0}
.rs-search-btn{width:46px;height:46px;background:rgba(255,255,255,.2);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;flex-shrink:0;transition:background .15s}
.rs-search-btn:hover{background:rgba(255,255,255,.3)}

/* En-tête résultats */
.rs-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap;padding-top:1.25rem}
.rs-header-title h1{font-size:1.3rem;font-weight:800;margin-bottom:.2rem}
.rs-job-label{color:var(--clr-text)}
.rs-city-label{color:var(--clr-muted);font-weight:400}
.rs-count{font-size:.85rem;color:var(--clr-muted);margin:0}
.rs-filter-count{color:var(--clr-primary);font-weight:600}

/* Tabs de tri */
.rs-sort-tabs{display:flex;gap:.35rem;flex-wrap:wrap}
.rs-sort-tab{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .85rem;border-radius:99px;font-size:.8rem;font-weight:600;color:var(--clr-muted);border:1.5px solid var(--clr-border);background:var(--clr-surface);text-decoration:none;transition:all .15s;white-space:nowrap}
.rs-sort-tab:hover{border-color:var(--clr-primary);color:var(--clr-primary)}
.rs-sort-tab.active{background:var(--clr-primary);color:#fff;border-color:var(--clr-primary)}

/* Pills filtres actifs */
.rs-active-filters{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1rem}
.rs-filter-pill{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .75rem;background:var(--clr-primary-l);color:var(--clr-primary);border-radius:99px;font-size:.78rem;font-weight:600;text-decoration:none;transition:background .15s;border:1px solid var(--clr-primary)}
.rs-filter-pill:hover{background:var(--clr-primary);color:#fff}
.rs-filter-pill i{font-size:.8rem}
.rs-filter-clear{font-size:.78rem;color:var(--clr-muted);display:inline-flex;align-items:center;gap:.3rem;text-decoration:none;padding:.3rem .5rem;border-radius:99px;transition:color .15s}
.rs-filter-clear:hover{color:var(--clr-danger)}

/* Bouton filtres mobile */
.rs-filters-toggle{display:none;align-items:center;gap:.5rem;margin-bottom:1rem;background:var(--clr-surface);border:1.5px solid var(--clr-border);border-radius:var(--radius-md);padding:.55rem 1rem;font-size:.875rem;font-weight:600;cursor:pointer;position:relative}
@media(max-width:899px){.rs-filters-toggle{display:inline-flex}}
.rs-filters-badge{background:var(--clr-primary);color:#fff;border-radius:99px;font-size:.65rem;font-weight:800;padding:.1rem .4rem;line-height:1.5;margin-left:.2rem}

/* Labels filtres dans sidebar */
.filter-group-label{display:flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:700;color:var(--clr-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.65rem}
.filter-ver-group{display:flex;gap:.5rem}
.filter-ver-option{flex:1;cursor:pointer}
.filter-ver-option input{display:none}
.filter-ver-option span{display:flex;align-items:center;justify-content:center;gap:.3rem;padding:.45rem .6rem;border:1.5px solid var(--clr-border);border-radius:var(--radius-sm);font-size:.8rem;font-weight:500;text-align:center;transition:all .15s;cursor:pointer;color:var(--clr-muted)}
.filter-ver-option.active span,.filter-ver-option input:checked+span{background:var(--clr-primary);color:#fff;border-color:var(--clr-primary)}
.range-minmax{display:flex;justify-content:space-between;font-size:.72rem;color:var(--clr-subtle);margin-top:.25rem}

/* Zone résultats */
.rs-results-area{min-width:0}

/* Pagination nouvelle */
.rs-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2.5rem}
.rs-page-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.2rem;border-radius:var(--radius-md);border:1.5px solid var(--clr-border);background:var(--clr-surface);font-size:.875rem;font-weight:600;color:var(--clr-text);text-decoration:none;transition:all .15s}
.rs-page-btn:hover{border-color:var(--clr-primary);color:var(--clr-primary);background:var(--clr-primary-l)}
.rs-page-btn.disabled{opacity:.4;pointer-events:none}
.rs-page-current{font-size:.875rem;color:var(--clr-muted);font-weight:500}

/* =====================================================
   PROVIDER CARDS - NOUVEAU DESIGN (pcard)
   ===================================================== */
.pcard{background:var(--clr-surface);border-radius:var(--radius-lg);border:1.5px solid var(--clr-border);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s,transform .15s,border-color .2s}
.pcard:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--clr-primary-l)}
.pcard-featured{border-color:var(--clr-gold)}
.pcard-featured:hover{border-color:var(--clr-gold)}
.pcard-ribbon{background:var(--clr-gold);color:#fff;font-size:.7rem;font-weight:700;padding:.2rem .85rem;text-align:center;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;justify-content:center;gap:.3rem}

.pcard-body{padding:1.25rem;flex:1;display:flex;flex-direction:column;gap:.65rem}

/* Avatar + infos principales */
.pcard-head{display:flex;gap:.85rem;align-items:flex-start}
.pcard-avatar-wrap{position:relative;flex-shrink:0}
.pcard-avatar{width:52px;height:52px;border-radius:50%;object-fit:cover;border:2px solid var(--clr-border);background:var(--clr-bg);display:block}
.pcard-avatar-dot{position:absolute;bottom:1px;right:1px;width:13px;height:13px;border-radius:50%;border:2px solid #fff}
.pcard-dot-identity{background:#3b82f6}
.pcard-dot-activity{background:var(--clr-primary)}
.pcard-dot-premium{background:var(--clr-gold)}
.pcard-info{flex:1;min-width:0}
.pcard-name{font-size:.95rem;font-weight:700;color:var(--clr-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0 0 .2rem}
.pcard-location{font-size:.78rem;color:var(--clr-muted);display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}
.pcard-distance{color:var(--clr-primary);font-weight:600}

/* Badge */
.pcard-badge{display:flex}

/* Headline */
.pcard-headline{font-size:.84rem;color:var(--clr-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin:0}

/* Skills */
.pcard-skills{display:flex;flex-wrap:wrap;gap:.3rem}
.pcard-skill{background:var(--clr-bg);border:1px solid var(--clr-border);border-radius:99px;padding:.15rem .6rem;font-size:.72rem;color:var(--clr-muted)}

/* Méta */
.pcard-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-top:auto}
.pcard-rating{display:inline-flex;align-items:center;gap:.3rem}
.pcard-rating-val{font-size:.875rem;font-weight:700;color:var(--clr-text)}
.pcard-stars{display:inline-flex;gap:1px;font-size:.82rem;color:var(--clr-gold)}
.pcard-rating-count{font-size:.75rem;color:var(--clr-subtle)}
.pcard-no-rating{font-size:.78rem;color:var(--clr-subtle);font-style:italic}
.pcard-exp{font-size:.78rem;color:var(--clr-muted);display:inline-flex;align-items:center;gap:.25rem}
.pcard-exp i{color:var(--clr-primary)}
.pcard-price{font-size:.875rem;color:var(--clr-text)}
.pcard-price strong{color:var(--clr-primary);font-weight:700}

/* CTA double */
.pcard-cta{padding:1rem 1.25rem;border-top:1px solid var(--clr-border);display:flex;gap:.5rem}
.pcard-btn-profile{flex:1;justify-content:center}
.pcard-btn-contact{flex:1;justify-content:center}

/* =====================================================
   ONBOARDING MODAL
   ===================================================== */
.ob-overlay{position:fixed;inset:0;background:rgba(15,23,42,.65);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .35s ease;backdrop-filter:blur(4px)}
.ob-overlay.ob-open{opacity:1;pointer-events:all}
.ob-overlay.ob-leaving{opacity:0;pointer-events:none}
.ob-modal{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:480px;padding:2.25rem 2rem;position:relative;max-height:90vh;overflow-y:auto;transform:translateY(20px);transition:transform .35s ease}
.ob-overlay.ob-open .ob-modal{transform:translateY(0)}
.ob-close{position:absolute;top:1rem;right:1rem;background:var(--clr-bg);border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--clr-muted);transition:background .15s}
.ob-close:hover{background:var(--clr-border);color:var(--clr-text)}
.ob-logo{font-size:1.1rem;font-weight:800;color:var(--clr-primary);margin-bottom:1.5rem}
.ob-logo span{color:var(--clr-gold)}
.ob-title{font-size:1.25rem;font-weight:800;color:var(--clr-text);margin-bottom:.5rem;line-height:1.3}
.ob-sub{font-size:.875rem;color:var(--clr-muted);margin-bottom:1.5rem;line-height:1.6}
.ob-step-hidden{display:none}
.ob-choices{display:flex;flex-direction:column;gap:.65rem;margin-bottom:1.25rem}
.ob-choice{display:flex;align-items:center;gap:.85rem;padding:1rem 1.1rem;background:var(--clr-bg);border:1.5px solid var(--clr-border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;transition:all .15s;color:var(--clr-text)}
.ob-choice:hover{border-color:var(--clr-primary);background:var(--clr-primary-l)}
.ob-choice-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--clr-primary-l);color:var(--clr-primary);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.ob-choice strong{display:block;font-size:.9rem;font-weight:700;margin-bottom:.15rem}
.ob-choice span{font-size:.78rem;color:var(--clr-muted)}
.ob-choice>i{margin-left:auto;color:var(--clr-subtle);flex-shrink:0}
.ob-skip{background:none;border:none;cursor:pointer;font-size:.8rem;color:var(--clr-subtle);padding:.5rem;display:flex;align-items:center;gap:.3rem;margin:0 auto;transition:color .15s}
.ob-skip:hover{color:var(--clr-muted)}
.ob-progress{height:4px;background:var(--clr-border);border-radius:99px;margin-bottom:1.5rem;overflow:hidden}
.ob-progress-bar{height:100%;background:var(--clr-primary);border-radius:99px;transition:width .3s ease}
.ob-back{background:none;border:none;cursor:pointer;font-size:1rem;color:var(--clr-muted);padding:.25rem .5rem;margin-bottom:.75rem;display:flex;align-items:center;gap:.3rem;transition:color .15s}
.ob-back:hover{color:var(--clr-text)}
.ob-search-wrap{margin-bottom:1rem}
.ob-quick-picks{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem}
.ob-pick{background:var(--clr-bg);border:1.5px solid var(--clr-border);border-radius:99px;padding:.35rem .85rem;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s;color:var(--clr-muted)}
.ob-pick:hover,.ob-pick.active{background:var(--clr-primary-l);border-color:var(--clr-primary);color:var(--clr-primary)}
.ob-provider-benefits{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin-bottom:0}
.ob-provider-benefits li{display:flex;align-items:center;gap:.65rem;font-size:.875rem;color:var(--clr-text)}
.ob-provider-benefits i{color:var(--clr-primary);font-size:1rem;flex-shrink:0}


/* ============================================================
   SEO mesh blocks (homepage + landing pages /{job}/{city})
   ============================================================ */
.seo-mesh-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:1rem}
.seo-mesh-col{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--r-lg,12px);padding:1.25rem 1.5rem}
.seo-mesh-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;margin:0 0 .85rem;color:var(--clr-text);font-weight:700}
.seo-mesh-title i{color:var(--clr-primary)}
.seo-mesh-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}
.seo-mesh-list li a{display:flex;align-items:center;justify-content:space-between;gap:.75rem;color:var(--clr-text);text-decoration:none;font-size:.9rem;padding:.4rem .15rem;border-bottom:1px dashed var(--clr-border);transition:color .15s}
.seo-mesh-list li:last-child a{border-bottom:none}
.seo-mesh-list li a:hover{color:var(--clr-primary)}
.seo-mesh-list-combos li a{font-size:.875rem}
.seo-mesh-prov{font-size:.7rem;color:var(--clr-muted);background:var(--clr-bg-2);padding:.1rem .5rem;border-radius:99px;font-weight:600}
@media (max-width:900px){.seo-mesh-grid{grid-template-columns:1fr}}

/* Landing /{job}/{city} : intro + maillage */
.seo-landing-intro{background:var(--clr-bg-2);border-left:4px solid var(--clr-primary);padding:1.25rem 1.5rem;border-radius:0 var(--r-lg,12px) var(--r-lg,12px) 0;margin:1.25rem 0 2rem;line-height:1.7}
.seo-landing-intro p{margin:0 0 .65rem;color:var(--clr-text-2)}
.seo-landing-intro p:last-child{margin-bottom:0}
.seo-related{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin:2rem 0 1rem}
.seo-related-block{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--r-lg,12px);padding:1.15rem 1.4rem}
.seo-related-block h3{font-size:1rem;margin:0 0 .75rem;color:var(--clr-text)}
.seo-related-chips{display:flex;flex-wrap:wrap;gap:.45rem}
.seo-related-chips a{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .8rem;background:var(--clr-bg-2);color:var(--clr-text);border-radius:99px;font-size:.825rem;text-decoration:none;border:1px solid transparent;transition:all .15s}
.seo-related-chips a:hover{background:var(--clr-primary-l);color:var(--clr-primary);border-color:var(--clr-primary)}
@media (max-width:700px){.seo-related{grid-template-columns:1fr}}

/* Footer SEO links (villes/métiers) */
.footer-seo{padding:1.25rem 0;border-top:1px solid rgba(255,255,255,.08);margin-top:1.5rem}
.footer-seo h5{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:rgba(255,255,255,.55);margin:0 0 .55rem;font-weight:700}
.footer-seo-row{display:flex;flex-wrap:wrap;gap:.4rem .75rem;margin-bottom:1rem}
.footer-seo-row a{font-size:.78rem;color:rgba(255,255,255,.7);text-decoration:none;transition:color .15s}
.footer-seo-row a:hover{color:#fff;text-decoration:underline}
