/* ================================================
   CHARTE OFFICIELLE ALEXIA.FR
   - Corps      : Plus Jakarta Sans (CDN Alexia)
   - Logo       : Varela Round
   - Icons      : Font Awesome 4 (CDN Alexia)
   - #000000    : texte de contenu
   - #0066AC    : titres et boutons secondaires
   - #FF8D00    : call to action
   - #FFA500    : &eacute;toiles avis
   - #FFFFFF    : fond
   - #F2F5F8    : fond alternance 1
   - #F0F8FF    : fond alternance 2
================================================ */

:root {
	--blue:        #0066AC;
	--blue-dark:   #004E87;
	--blue-bg:     #F0F8FF;
	--cta:         #FF8D00;
	--cta-dark:    #D97800;
	--text:        #000000;
	--white:       #FFFFFF;
	--bg-1:        #f1f9ff;
	--bg-2:        #F0F8FF;
	--star:        #FFA500;
	--muted:       #555555;
	--border:      #D0DCE8;
	--border-lt:   #E2ECF5;
	--sh-sm:       0 2px 12px rgba(0,102,172,.10);
	--sh-md:       0 6px 28px rgba(0,102,172,.13);
	--sh-lg:       0 16px 48px rgba(0,102,172,.17);
	--r:           10px;
	--r-lg:        16px;
}

.create_my_avo_account_for_postulation {cursor: pointer}

.rwh { z-index: 1; }

/* ============================================================
   LAYOUT
============================================================ */
.wrap {
	max-width: 1024px;
	margin: 0 auto;
	padding: 0 24px;
}
.section        { padding: 72px 0; }
.section--bg1   { background: var(--bg-1); }
.section--bg2   { background: var(--bg-2); }
.section--blue  { background: var(--blue); }
div#annu-ariane {
    z-index: 9;
    max-width: 1024px;
    margin: auto !important;
    width: 100%;
    display: block;
    text-align: left;
    margin-bottom: -40px !important;
    z-index: 9999;
    position: relative;
}

div#annu-ariane-bg {
    text-align: left;
}

.ariane-link-cont {
    text-align: left;
}

table#annu-ariane-cont {
    margin: 0px;
}
/* ============================================================
   TYPOGRAPHY
============================================================ */
.eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 11px;
	line-height: 1;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--blue);
	align-content: center;
	opacity: 0.65;
}
.eyebrow .fa {
	font-size: 16px;
	opacity: 0.65;
}

h1, h2, h3 {
	font-family: 'Plus Jakarta Sans', sans-serif;
	font-weight: 900;
	line-height: 1.3;
	color: var(--blue);
}
h1 { font-size: 58px; line-height: 1.0; }
.lp_barreau h1 { font-size: 40px; line-height: 1.0; }
h1 div { font-size: 24px; }
.lp_barreau h1 div { font-size: 40px; line-height: 1.0; }
.lp_barreau h1 span { display:block;font-size: 20px; line-height: 1.5;}
h2 { font-size: 36px; margin-top: 5px; margin-bottom: 5px; line-height: 1.1; }
h3 { font-size: 18px; }

.lead {
	font-size: 16px;
	font-weight: 400;
	color: var(--text);
	line-height: 1.3;
	max-width: 650px;
	text-align: justify;
}

.hl      { color: var(--cta); }
.hl-blue { color: var(--blue); }

.sh   { margin-bottom: 6px; }
.sh-c { text-align: center; }
.sh-c .lead { margin: 0 auto; }

/* ============================================================
   BUTTONS
============================================================ */
.btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 15px;
	border-radius: 6px;
	font-family: 'Plus Jakarta Sans', sans-serif;
	font-size: 16px;
	font-weight: 700;
	border: 2px solid transparent;
	cursor: pointer;
	white-space: nowrap;
	align-content: center;
	text-align: center;
	flex: 1;
	justify-content: center;
}
.btn-cta {
	background: var(--cta);
	color: var(--white);
	border-color: var(--cta);
}
.btn-cta:hover {
	background: var(--cta-dark);
	border-color: var(--cta-dark);
}
.btn-outline {
	background: transparent;
	color: var(--blue);
	border-color: var(--blue);
}
.btn-outline:hover {
	background: var(--blue);
	color: var(--white);
}
.btn-outline-white {
	background: transparent;
	color: var(--white);
	border-color: rgba(255,255,255,1);
}
.btn-outline-white:hover {
	border-color: var(--white);
	color: var(--blue);
	background: rgba(255,255,255,1);
}
.btn-row { display: flex; gap: 20px; flex-wrap: wrap; }

/* ============================================================
   HERO
============================================================ */
.hero {
	background: var(--bg-2);
	padding: 64px 0 56px;
	position: relative;
	overflow: hidden;
}
.hero::after {
	content: '';
	position: absolute;
	width: 480px;
	height: 480px;
	border-radius: 50%;
	background: rgba(0,102,172,.03);
	top: -140px;
	right: 5%;
	pointer-events: none;
	display: none;
}

.hero::before {
	content: '';
	position: absolute;
	width: 350px;
	height: 350px;
	border-radius: 50%;
	background: rgba(0,102,172,.08);
	bottom: -70px;
	right: 25%;
	pointer-events: none;
	display: none;
}
.hero .wrap {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr 450px;
	gap: 75px;
	align-items: center;
}
.hero h1             { margin-bottom: 18px; margin-top: 0; }
.hero h1 .hl         { color: var(--cta); }
.hero .lead          { margin-bottom: 10px; max-width: 500px; }
.hero__free {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 15px;
	font-weight: 500;
	color: var(--text);
	margin-bottom: 28px;
	line-height: 10px;
}
.hero__free b {
	font-weight: 700;
}

.hero__free .fa      { color: #2EAA2E; font-size: 20px;}
.hero__actions       { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; max-width: 500px; }

/* Carte hero */
.hero__card {
	background: var(--white);
	border: 1px solid var(--border-lt);
	border-radius: var(--r-lg);
	font-size: 0;
	position: relative;
}
.hero__card img {
	width: 100%;
	border-radius: var(--r-lg);
}

/* Badges flottants sur la carte hero */
.hero__recherche_1 {
	position: absolute;
	bottom: 25px;
	left: -25px;
	background: var(--white);
	border-radius: 8px;
	padding: 10px 14px;
	display: flex;
	flex-direction: column;
	line-height: 1.3;
	box-shadow: var(--sh-sm);
}
.hero__recherche_1 span:first-child { font-size: 13px; color: var(--text); }
.hero__recherche_1 span:last-child  { font-size: 17px; font-weight: 800; color: var(--blue); }

.hero__recherche_2 {
	position: absolute;
	top: 25px;
	right: -25px;
	background: var(--white);
	border-radius: 8px;
	padding: 10px 14px;
	display: flex;
	flex-direction: column;
	line-height: 1.3;
	box-shadow: var(--sh-sm);
}
.hero__recherche_2 span:first-child { font-size: 13px; color: var(--text); }
.hero__recherche_2 span:last-child  { font-size: 17px; font-weight: 800; color: var(--blue); }

/* ============================================================
   TRUST BAR
============================================================ */
.trust {
	background: var(--blue);
	padding: 20px;
}
.trust .wrap {
	display: flex;
	align-items: stretch;
}
.trust__item {
	flex: 1;
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 20px 18px;
	border-right: 1px solid rgba(255,255,255,.1);
	justify-content: center;
}
.trust__item img     { opacity: 0.65; }
.trust__item:last-child { border-right: none; }
.trust__item .fa     { font-size: 40px; color: rgba(255,255,255,.65); flex-shrink: 0; }
.trust__val          { font-size: 20px; font-weight: 900; color: var(--white); line-height: 1; margin-bottom: 2px; }
.trust__lbl          { font-size: 12px; color: rgba(255,255,255,.65); }

/* ============================================================
   INTRO (2 colonnes)
============================================================ */
.intro .wrap {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	align-items: center;
}
.check-list {
	list-style: none;
	margin: 20px 0 28px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 0;
	font-size: 16px;
}
.check-list li {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 16px;
	color: var(--text);
}
.check-list .fa { color: var(--blue); font-size: 22px; flex-shrink: 0; }

/* Illustration SVG */
.illu {
	background: var(--bg-2);
	border-radius: var(--r-lg);
	border: 1px solid var(--border-lt);
	aspect-ratio: 4/3;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: visible;
}
.illu svg { width: 88%; height: auto; }
.illu__badge {
	position: absolute;
	bottom: -18px;
	right: -18px;
	background: var(--white);
	border: 1px solid var(--border-lt);
	border-radius: var(--r);
	padding: 12px 16px;
	display: flex;
	align-items: center;
	gap: 10px;
	line-height: 1;
}
.illu__badge .fa     { font-size: 24px; color: var(--blue); }
.illu__badge strong  { display: block; font-size: 19px; font-weight: 800; color: var(--blue); line-height: 1; }
.illu__badge span    { font-size: 11px; color: var(--muted); }

/* ============================================================
   CARDS SERVICES (3)
============================================================ */
.cards-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
	margin-top: 40px;
}
.scard {
	background: var(--white);
	border: 1px solid var(--border-lt);
	border-left: 10px solid var(--blue);
	border-radius: 0 var(--r-lg) var(--r-lg) 0;
	padding: 24px 22px 22px;
	transition: box-shadow .18s, border-color .18s;
}

.scard__num {
	font-size: 52px;
	font-weight: 900;
	color: var(--border-lt);
	line-height: 1;
	margin-bottom: 2px;
	font-family: 'Plus Jakarta Sans', sans-serif;
}
.scard__row {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 14px;
}
.scard__row .fa {
	font-size: 20px;
	color: var(--blue);
	flex-shrink: 0;
}
.scard h3        { color: var(--blue); margin: 0; font-size: 18px; }
.scard__body     { font-size: 14px; color: var(--text); line-height: 1.5; margin: 0 0 12px; }
.scard__detail   { font-size: 13px; color: var(--muted); line-height: 1.5; margin: 0; padding-top: 12px; border-top: 1px solid var(--border-lt); }

/* ============================================================
   STEPS (3 &eacute;tapes)
============================================================ */
.steps {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
	margin-top: 44px;
	position: relative;
}
.steps::before {
	content: '';
	position: absolute;
	top: 22px;
	left: calc(16.66% + 14px);
	right: calc(16.66% + 14px);
	height: 1px;
	background: var(--border-lt);
}
.step            { text-align: center; position: relative; z-index: 1; }
.step__num {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--blue);
	color: var(--white);
	font-size: 16px;
	font-weight: 800;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 16px;
}
.step h3 { font-size: 16px; color: var(--blue); margin-bottom: 8px; }
.step p  { font-size: 14px; color: var(--muted); line-height: 1.3; }

/* ============================================================
   CAROUSEL AVOCATS
============================================================ */
.caro__outer {
	position: relative;
	margin-top: 36px;
}
.caro__viewport {
	overflow: hidden;
	width: 100%;
}
.caro__track {
	display: flex;
	gap: 18px;
	transition: transform .35s ease;
	will-change: transform;
}
.caro__item {
	flex: 0 0 calc(25% - 14px); /* (100% - 3*18px) / 4 */
	background: var(--white);
	border: 1px solid var(--border-lt);
	border-radius: var(--r);
	padding: 0;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	overflow: hidden;
	transition: box-shadow .18s, border-color .18s;
	padding: 20px;
	box-sizing: border-box;
}
.caro__item:hover {
	box-shadow: var(--sh-sm);
	border-color: var(--border);
}
.caro__item-link {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	padding: 0px;
	text-decoration: none;
	flex: 1;
}
.caro__item .btn {
	margin-top: 20px;
	padding: 10px;
}
.caro__avatar {
	width: 60%;
	aspect-ratio: 1 / 1;
	border-radius: 50%;
	object-fit: cover;
	object-position: center top;
	background-color: var(--bg-2);
	display: block;
	margin: 0 auto 8px;
}
.caro__name {
	font-size: 16px;
	font-weight: 700;
	color: var(--blue);
	line-height: 1.2;
	text-overflow: ellipsis;
	white-space: nowrap;
	overflow: hidden;
	max-width: 100%;
}
.caro__barreau {
	font-size: 13px;
	color: var(--muted);
	line-height: 1.2;
	margin-bottom: 4px;
	text-overflow: ellipsis;
	white-space: nowrap;
	overflow: hidden;
	max-width: 100%;
}
.caro__stars {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 2px;
	flex-wrap: nowrap;
}
.caro__star      { font-size: 13px; color: var(--border); }
.caro__star--on  { color: var(--star); }
.caro__nb-avis   { font-size: 13px; color: var(--muted); margin-left: 3px; }
.caro__reco {
	font-size: 13px;
	color: var(--blue);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
}
.caro__reco .fa  { font-size: 13px; color: var(--blue); opacity: .65; }
.caro__anciennete {
	font-size: 13px;
	color: var(--muted);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
}
.caro__anciennete .fa { font-size: 13px; opacity: .55; }
.caro__btn-contact {
	display: block;
	width: 100%;
	padding: 10px 0;
	border: none;
	border-top: 1px solid var(--border-lt);
	background: var(--bg-1);
	color: var(--blue);
	font-family: 'Plus Jakarta Sans', sans-serif;
	font-size: 16px;
	font-weight: 700;
	cursor: pointer;
	text-align: center;
	transition: background .15s, color .15s;
	text-decoration: none;
}
.caro__btn-contact:hover { background: var(--blue); color: var(--white); }
.caro__btn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	border: 1px solid var(--border);
	background: var(--white);
	color: var(--blue);
	font-size: 13px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: var(--sh-sm);
	transition: background .15s, color .15s, border-color .15s;
}
.caro__btn:hover:not(:disabled) { background: var(--blue); color: var(--white); border-color: var(--blue); }
.caro__btn:disabled              { opacity: .25; cursor: default; }
#caro-prev { left: -18px; }
#caro-next { right: -18px; }

/* ============================================================
   DERNIÈRES ANNONCES
============================================================ */
.ann__list {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.ann__item {
	display: flex;
	align-items: center;
	gap: 28px;
	padding: 24px 28px;
	background: var(--white);
	border: 1px solid var(--border-lt);
	border-radius: var(--r-lg);
	transition: box-shadow .18s, border-color .18s;
}
.ann__item:hover { box-shadow: var(--sh-sm); border-color: var(--border); }
.ann__body       { flex: 1; min-width: 0; }
.ann__titre {
	font-size: 15px;
	font-weight: 700;
	color: var(--blue);
	line-height: 1.35;
	margin-bottom: 6px;
}
.ann__desc {
	font-size: 13px;
	color: var(--muted);
	line-height: 1.5;
	margin: 0 0 14px;
}
.ann__tags       { display: flex; flex-wrap: wrap; gap: 6px; }
.ann__tag {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 12px;
	color: var(--muted);
	background: var(--bg-1);
	border: 1px solid var(--border-lt);
	border-radius: 4px;
	padding: 4px 10px;
	white-space: nowrap;
}
.ann__tag .fa    { font-size: 11px; color: var(--blue); opacity: .7; }
.ann__tag b      { color: var(--text); font-weight: 600; }
.ann__action     { flex-shrink: 0; }
.ann__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 18px;
	border: 2px solid var(--blue);
	border-radius: 6px;
	font-size: 13px;
	font-weight: 700;
	color: var(--blue);
	background: transparent;
	text-decoration: none;
	white-space: nowrap;
	transition: background .15s, color .15s;
}
.ann__btn .fa    { font-size: 12px; }
.ann__btn:hover  { background: var(--blue); color: var(--white); }

/* ============================================================
   STATS (fond bleu)
============================================================ */
.stats-inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 56px;
	align-items: center;
}
.stats-inner .btn-outline         { color: var(--white); border-color: var(--white); }
.stats-inner .btn-outline:hover   { background-color: var(--white); color: var(--blue); border-color: var(--white); }
.stats-inner .eyebrow             { color: rgba(255,255,255,.7); }
.stats-inner h2                   { color: var(--white); margin-bottom: 14px; }
.stats-inner h2 .hl               { color: #FFD4A0; }
.stats-inner .lead                { color: var(--white); max-width: 550px; }
.stats-nums {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1px;
	background: rgba(255,255,255,.1);
	border-radius: var(--r-lg);
	overflow: hidden;
}
.stat-box {
	background: rgba(255,255,255,.05);
	padding: 50px 20px;
	text-align: center;
}
.stat-box__num {
	font-size: 40px;
	font-weight: 800;
	color: var(--white);
	line-height: 1;
	margin-bottom: 6px;
}
.stat-box__num .hl {
	color: #FFD4A0;
	line-height: 40px;
	height: 40px;
	display: inline-block;
	overflow: hidden;
}
.stat-box__num .hl.inf { font-size: 70px; }
.stat-box__lbl         { font-size: 16px; color: var(--white); }

/* ============================================================
   WHY GRID (4 items)
============================================================ */
.why-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 14px;
	margin-top: 36px;
}
.why-item {
	display: flex;
	gap: 14px;
	background: var(--white);
	border: 1px solid var(--border-lt);
	border-radius: var(--r);
	padding: 22px;
	align-items: center;
}
.why-item img    { height: 80px; opacity: 0.35; }
.why-item:hover  { box-shadow: var(--sh-sm); }
.why-item h3     { font-size: 16px; color: var(--blue); margin: 0; }
.why-item p      { font-size: 14px; color: var(--muted); line-height: 1.3; margin: 0; }

/* ============================================================
   FAQ
============================================================ */
.faq-list {
	max-width: 1024px;
	margin: 40px auto 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.faq-item {
	background: var(--white);
	border: 1px solid var(--border-lt);
	border-radius: var(--r);
	overflow: hidden;
}
.faq-item.open   { border-color: var(--border); }
.faq-btn {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 18px 20px;
	background: none;
	border: none;
	cursor: pointer;
	text-align: left;
	font-family: 'Plus Jakarta Sans', sans-serif;
}
.faq-q { font-size: 16px; font-weight: 700; color: var(--blue); }
.faq-arrow {
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background: var(--bg-1);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.faq-arrow .fa                          { font-size: 13px; color: var(--blue); }
.faq-item.open .faq-arrow               { background: var(--blue); }
.faq-item.open .faq-arrow .fa           { color: var(--white); transform: rotate(180deg); }
.faq-body                               { max-height: 0; overflow: hidden; }
.faq-item.open .faq-body                { max-height: 200px; }
.faq-a { padding: 0 20px 18px; font-size: 16px; color: var(--muted); line-height: 1.7; }

/* ============================================================
   FINAL CTA (fond bleu)
============================================================ */
.final-cta {
	background: var(--blue);
	padding: 80px 0;
	text-align: center;
}
.final-cta h2          { color: var(--white); margin-bottom: 14px; }
.final-cta h2 .hl      { color: #FFD4A0; }
.final-cta p           { color: var(--white); font-size: 15px; max-width: 520px; margin: 0 auto 32px; line-height: 1.3; }
.final-cta .btn-row    { justify-content: center; max-width: 500px; margin: auto; }

/* ============================================================
   BLOC BARREAUX
============================================================ */
._nda_liste          { margin-top: 28px; }
._nda_liste a {
	display: inline-block;
	font-size: 14px;
	line-height: 1.8;
	font-weight: 500;
	color: var(--text);
	text-decoration: none;
}
._nda_liste a:hover  { color: var(--blue); }

/* ============================================================
   FOOTER
============================================================ */
.footer {
	background: #004480;
	padding: 18px 24px;
	text-align: center;
	font-size: 12px;
	color: rgba(255,255,255,.35);
}
.footer a        { color: rgba(255,255,255,.5); }
.footer a:hover  { color: var(--white); }

/* ============================================================
   RESPONSIVE
============================================================ */
@media (max-width: 920px) {
	.wrap {padding-left: 10px;padding-right: 10px;}
	.hero__free { font-size: 13.5px}
	.hero .wrap                 { grid-template-columns: 1fr; }
	.hero__card                 { display: none; }
	.intro .wrap                { grid-template-columns: 1fr; }
	.illu                       { display: none; }
	.cards-grid                 { grid-template-columns: 1fr; }
	.steps                      { grid-template-columns: 1fr; }
	.steps::before              { display: none; }
	.why-grid                   { grid-template-columns: 1fr; }
	.stats-inner                { grid-template-columns: 1fr; gap: 36px; }
	.caro__item                 { flex: 0 0 calc(50% - 9px); }
	.ann__item                  { flex-direction: column; align-items: flex-start; gap: 16px; }
	.ann__action                { width: 100%; }
	.ann__btn                   { width: 100%; justify-content: center; box-sizing: border-box;}
	h1 div {
		font-size: 15px;
		margin-bottom: 5px;
	}
	.hero h1 {
		font-size: 38px;
		line-height: 1.0;
	}
	h2 {
		font-size: 26px;
	}
	.hero::after {
		content: '';
		position: absolute;
		width: 480px;
		height: 480px;
		border-radius: 50%;
		background: rgba(0, 102, 172, .03);
		top: -140px;
		right: -50px;
		pointer-events: none;
	}
    .hero::before {
        content: '';
        position: absolute;
        width: 350px;
        height: 350px;
        border-radius: 50%;
        background: rgba(0, 102, 172, .07);
        bottom: -70px;
        right: auto;
        pointer-events: none;
        left: -75px;
    }
	
	ul.check-list b {
		display: block;
	}
	
	.trust {
		padding-left: 7.5px;
		padding-right: 7.5px;
	}
	
	.trust__val {
        font-size: 10px;
        max-width: 75px;
    }
	.trust__lbl {
		font-size: 8px;
		line-height: 1.1;
		color: rgba(255, 255, 255, .85);
		max-width: 75px;
	}
	.trust .wrap                { flex-wrap: wrap; padding: 0px;gap:7.5px}
	.trust__item                { border: 0px solid rgba(255,255,255,.08); padding: 0px;column-gap: 2.5px}
	
}
@media (max-width: 560px) {
	.section                    { padding: 48px 0; }
	.hero                       { padding: 48px 0 40px; }
	.caro__item                 { flex: 0 0 calc(100% - 0px); }
}
/* ============================================================
   HERO MOCKUP ANNONCES — anim&eacute;
============================================================ */
.hero-wrap {
	position: relative;
	padding-top: 52px;
	padding-bottom: 44px;
}

/* Carte principale */
.mock-card {
	width: 100%;
	background: #f8f9fa;
	border: 1.5px solid #dee2e6;
	border-radius: 14px;
	overflow: hidden;
	position: relative;
}

/* Barre browser */
.mock-bar {
	background: #e9ecef;
	height: 32px;
	display: flex;
	align-items: center;
	padding: 0 12px;
	border-bottom: 1px solid #dee2e6;
	gap: 0;
}
.mock-dot              { width: 10px; height: 10px; border-radius: 50%; margin-right: 6px; flex-shrink: 0; }
.mock-dot.r            { background: #ff5f57; }
.mock-dot.y            { background: #ffbd2e; }
.mock-dot.g            { background: #28c840; }
.mock-url {
	margin-left: 10px;
	background: #ffffff;
	border: 1px solid #dee2e6;
	border-radius: 4px;
	padding: 2px 12px;
	font-size: 10px;
	color: #adb5bd;
	flex: 1;
	max-width: 220px;
	white-space: nowrap;
	overflow: hidden;
}

/* En-t&ecirc;tes colonnes */
.mock-head {
	background: #edf2f7;
	border-bottom: 1px solid #dee2e6;
	display: grid;
	grid-template-columns: 94px 1fr 90px 110px;
	padding: 7px 12px;
	gap: 8px;
}
.mock-head span {
	font-size: 8.5px;
	font-weight: 700;
	color: #6c757d;
	letter-spacing: .05em;
	text-transform: uppercase;
}

/* Zone scrollable */
.mock-scroll-outer {
	height: 288px;
	overflow: hidden;
	position: relative;
}
.mock-scroll-inner {
	animation: mockScrollRows 12s linear infinite;
}
@keyframes mockScrollRows {
	0%   { transform: translateY(0); }
	80%  { transform: translateY(-216px); }
	90%  { transform: translateY(-216px); }
	100% { transform: translateY(0); }
}

/* Rows */
.mock-row {
	display: grid;
	grid-template-columns: 94px 1fr 90px 110px;
	align-items: center;
	gap: 8px;
	padding: 14px 12px;
	border-bottom: 1px solid #dee2e6;
	min-height: 72px;
}
.mock-row.hl { background: #edf4ff; border-left: 3px solid #0066AC; }
.mock-row.wh { background: #ffffff; }

/* Badge type */
.mock-row .badge {
	display: inline-block;
	padding: 4px 10px;
	border-radius: 4px;
	font-size: 9.5px;
	font-weight: 700;
	white-space: nowrap;
}
.mock-row .badge.post { background: #dbeafe; color: #1e40af; }
.mock-row .badge.vac  { background: #fef9c3; color: #854d0e; }
.mock-row .badge.sous { background: #dcfce7; color: #14532d; }

/* Barres titre */
.bars { display: flex; flex-direction: column; gap: 6px; }
.bar  { height: 7px; border-radius: 3px; }
.bar.b1 { background: #0066AC; opacity: .22; width: 90%; }
.bar.b2 { background: #ced4da; width: 80%; }
.bar.b3 { background: #ced4da; width: 70%; }
.bar.s1 { background: #adb5bd; opacity: .5; width: 75%; margin-top: 2px; height: 5px; }
.bar.s2 { background: #dee2e6; width: 85%; margin-top: 2px; height: 5px; }
.bar.s3 { background: #dee2e6; width: 75%; margin-top: 2px; height: 5px; }

/* Col m&eacute;ta */
.meta { display: flex; flex-direction: column; gap: 5px; }
.meta .bar { width: 100%; }

/* Bouton dans row */
.mock-btn {
	background: #0066AC;
	color: #fff;
	font-size: 9px;
	font-weight: 700;
	padding: 7px 10px;
	border-radius: 5px;
	text-align: center;
	white-space: nowrap;
	font-family: 'Plus Jakarta Sans', sans-serif;
}
.mock-btn.op7 { opacity: .7; }
.mock-btn.op5 { opacity: .5; }
.mock-btn.op3 { opacity: .3; }

/* Dégradé bas */
.mock-fade {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 60px;
	background: linear-gradient(to bottom, transparent, #f8f9fa);
	pointer-events: none;
}

/* Badges flottants */
.badge-float {
	position: absolute;
	background: var(--white);
	border: 1.5px solid var(--border-lt);
	border-radius: 10px;
	padding: 8px 14px;
	box-shadow: var(--sh-sm);
	white-space: nowrap;
	z-index: 3;
}
.badge-float .bf-label { font-size: 11px; color: var(--muted); line-height: 1.3; }
.badge-float .bf-value { font-size: 13px; font-weight: 700; color: var(--blue); line-height: 1.3; }

.badge-topright { top: 175px; right: -15px; display:none}
.badge-botleft  { bottom: 75px; left: -15px;display:none }

@media (max-width: 920px) {
	.hero-wrap  { display: none; }
}