/* =========================================================
   MagicFit — Portail front-office (candidat / franchisé)
   Identité : encre profonde + magenta énergique + menthe
   ========================================================= */

.mf-portail {
	--mf-ink: #17131f;
	--mf-magenta: #e4007c;
	--mf-magenta-d: #b80063;
	--mf-mint: #00c2a8;
	--mf-surface: #ffffff;
	--mf-soft: #f6f4f9;
	--mf-line: #e7e3ee;
	--mf-muted: #6a6475;

	max-width: 860px;
	margin: 0 auto;
	padding: 8px 0 48px;
	color: var(--mf-ink);
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	line-height: 1.55;
}
.mf-portail *, .mf-portail *::before, .mf-portail *::after { box-sizing: border-box; }

/* --- Logo --- */
.mf-logo {
	font-weight: 800;
	letter-spacing: .06em;
	font-size: 22px;
	color: var(--mf-ink);
}
.mf-logo span { color: var(--mf-magenta); }

/* --- En-tête --- */
.mf-portail__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 4px 18px;
	border-bottom: 2px solid var(--mf-ink);
	margin-bottom: 22px;
}
.mf-portail__user { display: flex; align-items: center; gap: 16px; font-weight: 600; }
.mf-link { color: var(--mf-magenta); text-decoration: none; font-weight: 600; }
.mf-link:hover { text-decoration: underline; }

/* --- Cartes --- */
.mf-card {
	background: var(--mf-surface);
	border: 1px solid var(--mf-line);
	border-radius: 16px;
	box-shadow: 0 8px 30px rgba(23,19,31,.05);
}
.mf-card--pad { padding: 26px 28px; }
.mf-h { font-size: 22px; margin: 0 0 6px; letter-spacing: -.01em; }
.mf-sub { color: var(--mf-muted); margin: 0 0 18px; }

/* --- Onglets --- */
.mf-tabs { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 20px; }
.mf-tab {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 10px 16px;
	border-radius: 999px;
	text-decoration: none;
	color: var(--mf-ink);
	background: var(--mf-soft);
	font-weight: 600;
	font-size: 14px;
	transition: background .15s ease, color .15s ease;
}
.mf-tab:hover { background: #ece7f3; }
.mf-tab--active { background: var(--mf-ink); color: #fff; }
.mf-tab__ico { font-size: 14px; }

/* --- Parcours (élément signature) --- */
.mf-parcours__intro { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.mf-chip {
	background: var(--mf-magenta);
	color: #fff;
	padding: 6px 14px;
	border-radius: 999px;
	font-weight: 700;
	font-size: 13px;
}
.mf-parcours { margin: 30px 0 10px; }
.mf-parcours__track {
	height: 6px;
	background: var(--mf-soft);
	border-radius: 999px;
	overflow: hidden;
	margin: 0 0 22px;
}
.mf-parcours__fill {
	height: 100%;
	width: var(--mf-progress, 0%);
	background: linear-gradient(90deg, var(--mf-magenta), var(--mf-mint));
	border-radius: 999px;
	transition: width .6s cubic-bezier(.4,0,.2,1);
}
.mf-steps {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 8px;
}
.mf-step { text-align: center; }
.mf-step__dot {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	margin: 0 auto 8px;
	border-radius: 50%;
	font-weight: 700;
	background: var(--mf-soft);
	color: var(--mf-muted);
	border: 2px solid var(--mf-line);
}
.mf-step__label { font-size: 12.5px; color: var(--mf-muted); display: block; }
.mf-step--done .mf-step__dot { background: var(--mf-mint); color: #fff; border-color: var(--mf-mint); }
.mf-step--current .mf-step__dot {
	background: var(--mf-magenta);
	color: #fff;
	border-color: var(--mf-magenta);
	box-shadow: 0 0 0 5px rgba(228,0,124,.15);
}
.mf-step--current .mf-step__label { color: var(--mf-ink); font-weight: 700; }
.mf-step--done .mf-step__label { color: var(--mf-ink); }

.mf-next { margin-top: 26px; padding-top: 20px; border-top: 1px solid var(--mf-line); }

/* --- Boutons --- */
.mf-btn {
	display: inline-block;
	padding: 12px 22px;
	border-radius: 999px;
	border: 1px solid var(--mf-ink);
	background: #fff;
	color: var(--mf-ink);
	font-weight: 700;
	text-decoration: none;
	cursor: pointer;
	font-size: 14px;
	transition: transform .12s ease, box-shadow .12s ease;
}
.mf-btn:hover { transform: translateY(-1px); }
.mf-btn--primary {
	background: var(--mf-magenta);
	border-color: var(--mf-magenta);
	color: #fff;
	box-shadow: 0 6px 18px rgba(228,0,124,.28);
}
.mf-btn--primary:hover { background: var(--mf-magenta-d); border-color: var(--mf-magenta-d); }

/* --- Champs de formulaire --- */
.mf-fields, .mf-upload, .mf-reply { display: flex; flex-wrap: wrap; gap: 14px; align-items: flex-end; }
.mf-field { display: flex; flex-direction: column; gap: 6px; flex: 1 1 220px; }
.mf-field--full { flex: 1 1 100%; }
.mf-field > span { font-size: 13px; font-weight: 600; }
.mf-portail input[type=text], .mf-portail input[type=email], .mf-portail input[type=tel],
.mf-portail input[type=number], .mf-portail input[type=password], .mf-portail textarea, .mf-portail select {
	width: 100%;
	padding: 11px 14px;
	border: 1px solid var(--mf-line);
	border-radius: 12px;
	font-size: 15px;
	font-family: inherit;
	background: #fff;
	color: var(--mf-ink);
}
.mf-portail input:focus, .mf-portail textarea:focus, .mf-portail select:focus {
	outline: none;
	border-color: var(--mf-magenta);
	box-shadow: 0 0 0 3px rgba(228,0,124,.12);
}
.mf-check { display: flex; align-items: flex-start; gap: 10px; margin: 14px 0; font-size: 14px; }
.mf-check input { margin-top: 3px; }

/* --- Connexion --- */
.mf-portail--login { max-width: 460px; padding-top: 40px; }
.mf-login { text-align: center; }
.mf-login .mf-logo { margin-bottom: 14px; font-size: 26px; }
.mf-login form { text-align: left; margin-top: 14px; }
.mf-login label { display: block; font-weight: 600; font-size: 13px; margin-bottom: 6px; }
.mf-login input[type=text], .mf-login input[type=password] {
	width: 100%; padding: 12px 14px; border: 1px solid var(--mf-line);
	border-radius: 12px; margin-bottom: 14px; font-size: 15px;
}
.mf-login .button, .mf-login input[type=submit] {
	width: 100%; padding: 12px; border-radius: 999px; border: none;
	background: var(--mf-magenta); color: #fff; font-weight: 700; font-size: 15px; cursor: pointer;
}
.mf-login__lost { margin-top: 14px; font-size: 13px; }
.login-remember { font-weight: 400 !important; font-size: 13px !important; }

/* --- Documents --- */
.mf-docs { list-style: none; margin: 22px 0 0; padding: 0; }
.mf-doc {
	display: grid;
	grid-template-columns: 150px 1fr auto;
	gap: 6px 16px;
	align-items: center;
	padding: 14px 0;
	border-top: 1px solid var(--mf-line);
}
.mf-doc__type { font-weight: 700; font-size: 13px; }
.mf-doc__name { font-size: 14px; }
.mf-doc__meta { grid-column: 2; font-size: 12px; color: var(--mf-muted); }
.mf-docs__empty { color: var(--mf-muted); padding: 14px 0; border-top: 1px solid var(--mf-line); }

/* --- Messagerie --- */
.mf-thread--front { display: flex; flex-direction: column; gap: 12px; margin: 8px 0 20px; }
.mf-portail .mf-msg { border-radius: 14px; padding: 12px 16px; max-width: 78%; }
.mf-msg--moi { background: var(--mf-ink); color: #fff; align-self: flex-end; border-bottom-right-radius: 4px; }
.mf-msg--siege { background: var(--mf-soft); align-self: flex-start; border-bottom-left-radius: 4px; }
.mf-portail .mf-msg__head { font-size: 11.5px; opacity: .75; margin-bottom: 5px; display: flex; gap: 12px; justify-content: space-between; }
.mf-portail .mf-msg__body p { margin: 0; }
.mf-reply textarea { flex: 1 1 100%; }

/* --- DIP / signature --- */
.mf-sign { margin-top: 20px; padding-top: 18px; border-top: 1px solid var(--mf-line); }

/* --- Alertes --- */
.mf-alert { padding: 14px 18px; border-radius: 12px; margin-bottom: 18px; font-size: 14px; }
.mf-alert--ok { background: #e2f7f1; color: #0a6b57; border: 1px solid #b6eadd; }
.mf-alert--err { background: #fdeaea; color: #9c1f1f; border: 1px solid #f4bcbc; }

.mf-badge--src { background: #efeaf6; color: #5b4b7a; }

/* --- Responsive --- */
@media (max-width: 640px) {
	.mf-steps { grid-template-columns: repeat(2, 1fr); gap: 16px 8px; }
	.mf-doc { grid-template-columns: 1fr auto; }
	.mf-doc__meta { grid-column: 1; }
	.mf-portail .mf-msg { max-width: 92%; }
	.mf-card--pad { padding: 20px 18px; }
}

/* --- Accessibilité --- */
@media (prefers-reduced-motion: reduce) {
	.mf-parcours__fill, .mf-btn { transition: none; }
}
.mf-portail a:focus-visible, .mf-portail button:focus-visible,
.mf-portail input:focus-visible, .mf-portail select:focus-visible {
	outline: 3px solid var(--mf-mint);
	outline-offset: 2px;
}

/* =========================================================
   Portail franchisé — actualités, documents, support
   ========================================================= */

/* Actualités */
.mf-actu { padding: 18px 0; border-top: 1px solid var(--mf-line); }
.mf-actu:first-of-type { border-top: none; padding-top: 4px; }
.mf-actu--pin .mf-actu__title { color: var(--mf-magenta); }
.mf-actu__title { font-size: 18px; margin: 0 0 4px; }
.mf-actu__meta { font-size: 12px; color: var(--mf-muted); margin-bottom: 8px; }
.mf-actu__body p { margin: 0 0 8px; }

/* Base documentaire */
.mf-doccat {
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--mf-muted);
	margin: 22px 0 4px;
}

/* Liste des tickets */
.mf-tickets { list-style: none; margin: 0; padding: 0; }
.mf-ticket { border-top: 1px solid var(--mf-line); }
.mf-ticket a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	padding: 14px 4px;
	text-decoration: none;
	color: var(--mf-ink);
}
.mf-ticket a:hover { color: var(--mf-magenta); }
.mf-ticket__subject { font-weight: 600; }

/* Puces de statut */
.mf-chip--ouvert   { background: #fff0d6; color: #a15c00; }
.mf-chip--en_cours { background: #d7ebff; color: #0a5aa3; }
.mf-chip--resolu   { background: #d4f4dd; color: #17663a; }
.mf-chip--ferme    { background: #e5e5e5; color: #555; }

/* =========================================================
   Identités distinctes par portail
   Candidat = magenta (défaut) · Franchisé = teal · Admin = indigo
   ========================================================= */
.mf-portail--franchise { --mf-magenta: #0e9f8e; --mf-magenta-d: #0b7d70; }
.mf-portail--admin     { --mf-magenta: #5b3df5; --mf-magenta-d: #4a2fd0; }

.mf-portail--admin .mf-logo em {
	font-style: normal;
	font-size: 12px;
	font-weight: 600;
	color: var(--mf-magenta);
	letter-spacing: .12em;
	text-transform: uppercase;
	margin-left: 4px;
}

/* =========================================================
   Espace admin — stats, tableaux, blocs
   ========================================================= */
.mf-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 12px;
	margin-top: 8px;
}
.mf-stat {
	background: var(--mf-soft);
	border-radius: 12px;
	padding: 18px 14px;
	text-align: center;
	text-decoration: none;
	color: var(--mf-ink);
	transition: transform .12s ease;
}
.mf-stat:hover { transform: translateY(-2px); }
.mf-stat__num { display: block; font-size: 30px; font-weight: 800; line-height: 1; color: var(--mf-magenta); }
.mf-stat__label { display: block; font-size: 12.5px; color: var(--mf-muted); margin-top: 6px; }

.mf-table { width: 100%; border-collapse: collapse; margin-top: 10px; }
.mf-table th {
	text-align: left;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: .05em;
	color: var(--mf-muted);
	padding: 8px 10px;
	border-bottom: 2px solid var(--mf-line);
}
.mf-table td { padding: 12px 10px; border-bottom: 1px solid var(--mf-line); vertical-align: top; }
.mf-table small { color: var(--mf-muted); }

.mf-sub-block { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--mf-line); }
.mf-reply__foot { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; margin-top: 10px; }

@media (max-width: 640px) {
	.mf-stats { grid-template-columns: repeat(2, 1fr); }
}

/* Actions dans les tableaux (espace admin) */
.mf-rowact { white-space: nowrap; }
.mf-rowact .mf-inline { display: inline; }
.mf-linkbtn {
	background: none; border: none; padding: 0; margin: 0;
	color: var(--mf-magenta); font: inherit; font-weight: 600; cursor: pointer;
}
.mf-linkbtn:hover { text-decoration: underline; }
.mf-linkbtn--danger { color: #c0392b; }
.mf-muted { color: var(--mf-muted); font-size: 13px; }
