/* =========================================================
   AFFILIATION / ADMIN MODERN CSS
   Version corrigée et nettoyée
   ========================================================= */

/* ------------------------------
   Structure générale
------------------------------ */

.affiliation-page {
	max-width: 1180px;
	margin: 0 auto;
	padding-bottom: 40px;
}

.admin-edit-page {
	max-width: 1280px;
	margin: 0 auto;
	padding-bottom: 40px;
}

/* ------------------------------
   Cartes
------------------------------ */

.affiliation-card,
.admin-decision-card {
	background: #fff;
	border-radius: 18px;
	border: 1px solid #edf0f5;
	box-shadow: 0 8px 30px rgba(31, 45, 61, 0.06);
	margin-bottom: 22px;
	overflow: visible;
	position: relative;
}

.affiliation-card__header,
.admin-decision-card__header {
	padding: 20px 24px;
	border-bottom: 1px solid #edf0f5;
	display: flex;
	align-items: center;
	gap: 14px;
}

.affiliation-card__icon,
.admin-decision-card__icon {
	width: 42px;
	height: 42px;
	border-radius: 14px;
	background: rgba(238, 90, 36, .10);
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	flex: 0 0 42px;
}

.affiliation-card__icon i,
.admin-decision-card__icon i {
	line-height: 1;
}

.affiliation-card__header h3,
.admin-decision-card__header h3 {
	margin: 0;
	font-size: 18px;
	font-weight: 900;
	color: #2f3044;
}

.affiliation-card__header span,
.admin-decision-card__header span {
	display: block;
	margin-top: 3px;
	font-size: 13px;
	color: #74788d;
}

.affiliation-card__body {
	padding: 24px;
	overflow: visible;
	position: relative;
	z-index: 1;
}

.admin-decision-card .affiliation-card__body {
	overflow: visible !important;
}

.admin-decision-card {
	z-index: 5;
}

.admin-decision-card:has(.chosen-container-active) {
	z-index: 100;
}

/* ------------------------------
   Top action / en-têtes de page
------------------------------ */

.affiliation-top-action {
	background: #ffffff;
	border: 1px solid #edf0f5;
	border-radius: 18px;
	box-shadow: 0 8px 30px rgba(31, 45, 61, 0.06);
	padding: 20px 24px;
	margin-bottom: 18px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
}

.affiliation-top-action__left {
	display: flex;
	align-items: center;
	gap: 18px;
}

.affiliation-top-action__icon {
	width: 46px;
	height: 46px;
	border-radius: 14px;
	background: rgba(238, 90, 36, .10);
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
	flex: 0 0 46px;
}

.affiliation-top-action h3 {
	margin: 0;
	font-size: 18px;
	font-weight: 800;
	color: #2f3044;
}

.affiliation-top-action p {
	margin: 5px 0 0 0;
	color: #74788d;
	font-size: 13px;
}

.affiliation-top-action__right {
	display: flex !important;
	align-items: center !important;
	justify-content: flex-end !important;
	gap: 10px !important;
	flex-wrap: wrap !important;
}

.affiliation-inline-form {
	margin: 0 !important;
	padding: 0 !important;
	display: inline-flex !important;
}

/* Boutons du bloc fiche joueur : prise de contrôle / fonctions / archives */
.affiliation-top-action__right .aff-action-btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 8px !important;
	min-height: 42px !important;
	padding: 0 16px !important;
	border-radius: 12px !important;
	border: 1px solid #dbe3ea !important;
	background: #f8fafc !important;
	color: #132238 !important;
	font-size: 13px !important;
	font-weight: 800 !important;
	line-height: 1 !important;
	text-decoration: none !important;
	box-shadow: 0 4px 12px rgba(15, 34, 54, .05) !important;
	cursor: pointer !important;
	transition: all .18s ease !important;
}

.affiliation-top-action__right .aff-action-btn i {
	font-size: 16px !important;
	color: #ee5a24 !important;
	line-height: 1 !important;
}

.affiliation-top-action__right .aff-action-btn:hover {
	background: #eef4f8 !important;
	border-color: #c9d5df !important;
	color: #0f2236 !important;
	text-decoration: none !important;
	transform: translateY(-1px) !important;
	box-shadow: 0 8px 18px rgba(15, 34, 54, .08) !important;
}

.affiliation-top-action__right .aff-action-btn--control {
	background: #fff4ec !important;
	border-color: #ffd4bd !important;
	color: #c2410c !important;
}

.affiliation-top-action__right .aff-action-btn--control:hover {
	background: #ffe8d8 !important;
	border-color: #ffbd95 !important;
	color: #9a3412 !important;
}

/* ------------------------------
   Hero
------------------------------ */

.affiliation-hero,
.admin-edit-hero {
	background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%);
	border-radius: 18px;
	padding: 28px 32px;
	margin-bottom: 24px;
	color: #fff;
	box-shadow: 0 12px 32px rgba(238, 90, 36, 0.22);
}

.admin-edit-hero {
	box-shadow: 0 18px 40px rgba(238, 90, 36, .20);
}

.affiliation-hero h2,
.admin-edit-hero h2 {
	margin: 0;
	font-size: 26px;
	font-weight: 900;
	color: #fff;
}

.affiliation-hero p,
.admin-edit-hero p {
	margin: 10px 0 0 0;
	opacity: .95;
	font-size: 15px;
	line-height: 1.5;
	color: rgba(255,255,255,.88);
	font-weight: 600;
}

/* ------------------------------
   Grilles et champs
------------------------------ */

.affiliation-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px 24px;
}

.affiliation-grid--full {
	grid-template-columns: 1fr;
}

.affiliation-field {
	position: relative;
}

.affiliation-field--full {
	grid-column: 1 / -1;
}

.affiliation-field label {
	display: block;
	font-weight: 700;
	color: #2f3044;
	margin-bottom: 8px;
	font-size: 13px;
}

.affiliation-field .form-control,
.affiliation-field select,
.affiliation-field .chosen-container {
	width: 100% !important;
}

.affiliation-field .form-control,
.affiliation-field select {
	border-radius: 10px;
	border: 1px solid #dfe3ec;
	min-height: 44px;
	padding: 10px 14px;
	transition: all .2s ease;
}

.affiliation-field .form-control:focus,
.affiliation-field select:focus {
	border-color: #ee5a24;
	box-shadow: 0 0 0 3px rgba(238, 90, 36, .10);
	outline: none;
}

.affiliation-field small {
	display: block;
	margin-top: 6px;
	color: #74788d;
}

.required-dot {
	color: #ee5a24;
	font-weight: 900;
}

/* ------------------------------
   Dates
------------------------------ */

.affiliation-date-row {
	display: grid;
	grid-template-columns: 1fr 1.2fr 1fr;
	gap: 10px;
}

.affiliation-date-row select,
.affiliation-date-row .form-control {
	width: 100% !important;
	min-height: 44px;
	border-radius: 10px;
	border: 1px solid #dfe3ec;
	padding: 10px 12px;
	background-color: #fff;
}

.affiliation-date-row select:focus,
.affiliation-date-row .form-control:focus {
	border-color: #ee5a24;
	box-shadow: 0 0 0 3px rgba(238, 90, 36, .10);
	outline: none;
}

/* ------------------------------
   Choix radio / cards
------------------------------ */

.affiliation-radio-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}

.affiliation-radio-card {
	position: relative;
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 14px 16px;
	border: 1px solid #dfe3ec;
	border-radius: 12px;
	background: #fff;
	cursor: pointer;
	transition: all .2s ease;
	min-height: 54px;
}

.affiliation-radio-card:hover {
	border-color: #ee5a24;
	background: #fff8f3;
}

.affiliation-radio-card input {
	margin-top: 3px;
}

.affiliation-radio-card strong {
	display: block;
	color: #2f3044;
	font-size: 14px;
}

.affiliation-radio-card span {
	display: block;
	color: #74788d;
	font-size: 12px;
	line-height: 1.35;
}

.affiliation-choice-row {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}

.affiliation-choice-row--two {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.affiliation-choice-card {
	position: relative;
	display: flex;
	align-items: center;
	gap: 12px;
	min-height: 58px;
	padding: 14px 16px;
	border: 1px solid #dfe3ec;
	border-radius: 14px;
	background: #fff;
	cursor: pointer;
	transition: all .2s ease;
	margin: 0;
}

.affiliation-choice-card--large {
	min-height: 82px;
	align-items: center;
}

.affiliation-choice-card:hover {
	border-color: #ee5a24;
	background: #fff8f3;
	box-shadow: 0 6px 18px rgba(238, 90, 36, .08);
}

.affiliation-choice-card input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.affiliation-choice-card .choice-icon {
	width: 34px;
	height: 34px;
	border-radius: 10px;
	background: #f4f6fb;
	color: #74788d;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
	transition: all .2s ease;
}

.affiliation-choice-card .choice-content strong {
	font-size: 14px;
	font-weight: 800;
	color: #2f3044;
}

.affiliation-choice-card .choice-content small {
	display: block;
	margin-top: 4px;
	font-size: 12px;
	font-weight: 600;
	color: #74788d;
	line-height: 1.35;
}

.affiliation-choice-card:has(input:checked) {
	border-color: #ee5a24;
	background: #fff4ec;
	box-shadow: 0 8px 22px rgba(238, 90, 36, .12);
}

.affiliation-choice-card:has(input:checked) .choice-icon {
	background: #ee5a24;
	color: #fff;
}

.affiliation-choice-card:has(input:checked) .choice-content small {
	color: #9a3412;
}

.affiliation-choice-card:has(input:checked)::after {
	content: "\2713";
	position: absolute;
	right: 16px;
	top: 50%;
	transform: translateY(-50%);
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: #ee5a24;
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	font-weight: 900;
}

/* ------------------------------
   Alertes et encarts
------------------------------ */

.affiliation-alert {
	display: flex;
	gap: 14px;
	padding: 16px 18px;
	border-radius: 14px;
	background: #fff7ed;
	border: 1px solid #fed7aa;
	color: #2f3044;
	margin-top: 14px;
}

.affiliation-alert i {
	font-size: 24px;
	color: #ee5a24;
	margin-top: 2px;
}

.affiliation-alert strong {
	color: #1f2937;
}

.admin-warning-box {
	background: #fff7ed;
	color: #9a3412;
	border: 1px solid #fed7aa;
	border-radius: 14px;
	padding: 14px 16px;
	font-size: 13px;
	font-weight: 700;
	display: flex;
	gap: 10px;
	align-items: flex-start;
}

.admin-warning-box i {
	color: #ee5a24;
	font-size: 20px;
	margin-top: 1px;
}

.admin-reminder-box {
	background: #fff7ed;
	border: 1px solid #fed7aa;
	border-radius: 16px;
	padding: 16px 18px;
	margin-bottom: 20px;
	display: flex;
	align-items: flex-start;
	gap: 12px;
}

.admin-reminder-box__icon {
	width: 38px;
	height: 38px;
	border-radius: 12px;
	background: rgba(238, 90, 36, .12);
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
	flex: 0 0 38px;
}

.admin-reminder-box__content {
	flex: 1;
}

.admin-reminder-box__title {
	font-size: 13px;
	font-weight: 900;
	color: #9a3412;
	margin-bottom: 6px;
	text-transform: uppercase;
	letter-spacing: .03em;
}

.admin-reminder-box__text {
	font-size: 13px;
	font-weight: 700;
	color: #7c2d12;
	line-height: 1.45;
}

.admin-reminder-box__text strong {
	color: #0f2236;
	font-weight: 900;
}

.admin-reminder-box__actions {
	margin-top: 10px;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

/* ------------------------------
   Boutons
------------------------------ */

.affiliation-actions {
	display: flex;
	justify-content: flex-end;
	gap: 12px;
	padding: 22px 24px;
	background: #fafbfc;
	border-top: 1px solid #edf0f5;
	border-radius: 0 0 18px 18px;
}

.btn-affiliation-main {
	background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%);
	border: none;
	color: #fff !important;
	border-radius: 12px;
	padding: 12px 22px;
	font-weight: 800;
	box-shadow: 0 8px 18px rgba(238, 90, 36, .22);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
}

.btn-affiliation-main:hover {
	color: #fff !important;
	transform: translateY(-1px);
	box-shadow: 0 10px 22px rgba(238, 90, 36, .28);
}

.btn-affiliation-secondary {
	border-radius: 12px;
	padding: 12px 18px;
	font-weight: 700;
}

.btn-affiliation-small {
	padding: 11px 18px;
	min-width: auto;
	white-space: nowrap;
}

.btn-admin-save {
	background: #0f2236;
	color: #fff !important;
	border: none;
	border-radius: 12px;
	padding: 12px 18px;
	font-weight: 900;
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.btn-admin-save:hover {
	background: #183653;
	color: #fff !important;
}

.btn-admin-validate {
	background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%);
	color: #fff !important;
	border: none;
	border-radius: 12px;
	padding: 12px 18px;
	font-weight: 900;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	box-shadow: 0 8px 18px rgba(238, 90, 36, .22);
}

.btn-admin-validate:hover {
	color: #fff !important;
	transform: translateY(-1px);
}

.btn-admin-secondary {
	background: #fff4ec;
	color: #ee5a24 !important;
	border: none;
	border-radius: 12px;
	padding: 12px 18px;
	font-weight: 900;
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.btn-admin-mini {
	border: none;
	border-radius: 10px;
	padding: 7px 10px;
	font-size: 12px;
	font-weight: 900;
	background: #ee5a24;
	color: #fff !important;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	cursor: pointer;
}

.btn-admin-mini:hover {
	background: #c2410c;
	color: #fff !important;
}

/* ------------------------------
   Chosen / select searchable
------------------------------ */

.affiliation-field .chosen-container,
.chosen-container {
	position: relative;
	z-index: 10;
	width: 100% !important;
	font-size: 14px;
}

.affiliation-field .chosen-container {
	z-index: 20;
}

.affiliation-field .chosen-container.chosen-with-drop,
.chosen-container.chosen-with-drop,
.chosen-container .chosen-drop {
	z-index: 9999 !important;
}

.affiliation-card:has(.chosen-with-drop) {
	z-index: 50;
}

.affiliation-field .chosen-container-single .chosen-single {
	height: 46px;
	line-height: 44px;
	border-radius: 12px;
	border: 1px solid #dfe3ec;
	background: #fff;
	box-shadow: none;
	padding: 0 42px 0 14px;
	color: #2f3044;
	font-weight: 600;
	transition: all .2s ease;
}

.affiliation-field .chosen-container-single .chosen-single div {
	width: 38px;
}

.affiliation-field .chosen-container-single .chosen-single div b {
	background-position: 0 13px;
}

.affiliation-field .chosen-container-active.chosen-with-drop .chosen-single,
.affiliation-field .chosen-container-active .chosen-single {
	border-color: #ee5a24;
	box-shadow: 0 0 0 3px rgba(238, 90, 36, .10);
}

.affiliation-field .chosen-container-single .chosen-drop {
	margin-top: 6px;
	border-radius: 14px;
	border: 1px solid #e5e7eb;
	box-shadow: 0 14px 35px rgba(31, 45, 61, .14);
	overflow: hidden;
}

.affiliation-field .chosen-container-single .chosen-search {
	padding: 12px;
	background: #fff;
}

.affiliation-field .chosen-container-single .chosen-search input[type="text"] {
	height: 42px;
	border-radius: 10px;
	border: 1px solid #dfe3ec;
	padding: 8px 36px 8px 12px;
	font-size: 14px;
	background-color: #f9fafb;
	background-position: right 12px center;
}

.affiliation-field .chosen-container-single .chosen-search input[type="text"]:focus {
	border-color: #ee5a24;
	box-shadow: 0 0 0 3px rgba(238, 90, 36, .10);
	outline: none;
	background-color: #fff;
}

.affiliation-field .chosen-container .chosen-results {
	margin: 0;
	padding: 6px;
	max-height: 230px;
}

.affiliation-field .chosen-container .chosen-results li {
	padding: 10px 12px;
	border-radius: 9px;
	font-weight: 600;
	color: #2f3044;
}

.affiliation-field .chosen-container .chosen-results li.highlighted {
	background: #ee5a24;
	color: #fff;
}

.affiliation-field .chosen-container .chosen-results li.result-selected {
	background: #fff4ec;
	color: #ee5a24;
}

.affiliation-field .chosen-container .chosen-results li.no-results {
	background: #fff7ed;
	color: #9a3412;
	border-radius: 9px;
}

/* ------------------------------
   Adresse autocomplete
------------------------------ */

.address-suggestions {
	display: none;
	position: absolute;
	left: 0;
	right: 0;
	top: calc(100% + 6px);
	background: #fff;
	border: 1px solid #e5e7eb;
	border-radius: 14px;
	box-shadow: 0 14px 35px rgba(31, 45, 61, .14);
	z-index: 9999;
	overflow: hidden;
	max-height: 280px;
	overflow-y: auto;
}

.address-suggestion-item {
	padding: 12px 14px;
	cursor: pointer;
	border-bottom: 1px solid #f1f5f9;
	font-weight: 700;
	color: #2f3044;
	transition: all .18s ease;
}

.address-suggestion-item:last-child {
	border-bottom: none;
}

.address-suggestion-item:hover {
	background: #fff4ec;
	color: #ee5a24;
}

.address-suggestion-main {
	display: block;
	font-size: 13px;
}

.address-suggestion-sub {
	display: block;
	margin-top: 3px;
	font-size: 12px;
	color: #74788d;
	font-weight: 600;
}

.address-suggestion-item:hover .address-suggestion-sub {
	color: #9a3412;
}

/* ------------------------------
   Fonctions / similarités / listes
------------------------------ */

.similarity-box {
	background: #fafbfc;
	border: 1px solid #edf0f5;
	border-radius: 14px;
	padding: 14px;
}

.similarity-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 10px 0;
	border-bottom: 1px solid #edf0f5;
}

.similarity-item:last-child {
	border-bottom: none;
}

.similarity-item a {
	color: #ee5a24;
	font-weight: 900;
}

.admin-office-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 5px 9px;
	border-radius: 999px;
	background: rgba(238, 90, 36, .12);
	color: #ee5a24;
	font-size: 11px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
}

/* ------------------------------
   Footer sticky admin
------------------------------ */

.admin-action-footer {
	position: sticky;
	bottom: 0;
	background: rgba(255, 255, 255, .94);
	backdrop-filter: blur(10px);
	border-top: 1px solid #edf0f5;
	padding: 18px 24px;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 12px;
	z-index: 20;
	border-radius: 0 0 18px 18px;
}

/* ------------------------------
   Responsive
------------------------------ */

@media (max-width: 991px) {
	.affiliation-grid,
	.affiliation-radio-grid {
		grid-template-columns: 1fr;
	}

	.affiliation-hero,
	.admin-edit-hero {
		padding: 22px;
	}
}

@media (max-width: 768px) {
	.affiliation-top-action {
		flex-direction: column;
		align-items: stretch;
	}

	.affiliation-top-action__left {
		align-items: flex-start;
	}

	.affiliation-top-action__right {
		justify-content: stretch !important;
	}

	.affiliation-top-action__right .aff-action-btn,
	.affiliation-inline-form {
		width: 100% !important;
	}

	.affiliation-top-action__right .aff-action-btn {
		min-height: 44px !important;
	}

	.affiliation-choice-row--two {
		grid-template-columns: 1fr;
	}

	.affiliation-hero h2,
	.admin-edit-hero h2 {
		font-size: 22px;
	}
}

@media (max-width: 576px) {
	.affiliation-date-row,
	.affiliation-choice-row {
		grid-template-columns: 1fr;
	}
}
/* ------------------------------
   Bloc fonctions joueur
------------------------------ */

.function-group {
	background: #ffffff;
	border: 1px solid #edf0f5;
	border-radius: 18px;
	box-shadow: 0 8px 24px rgba(31, 45, 61, 0.045);
	margin-bottom: 18px;
	overflow: visible;
	position: relative;
}

.function-group__header {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 18px 20px;
	border-bottom: 1px solid #edf0f5;
	background: #fbfcfe;
	border-radius: 18px 18px 0 0;
}

.function-group__icon {
	width: 38px;
	height: 38px;
	border-radius: 12px;
	background: rgba(238, 90, 36, .10);
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
	flex: 0 0 38px;
}

.function-group__header h4 {
	margin: 0;
	font-size: 15px;
	font-weight: 900;
	color: #0f2236;
}

.function-group__header span {
	display: block;
	margin-top: 3px;
	font-size: 12px;
	font-weight: 600;
	color: #74788d;
}

.function-group__body {
	padding: 18px 20px;
	overflow: visible;
	position: relative;
}

.function-empty {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 9px 12px;
	border-radius: 999px;
	background: #f8fafc;
	border: 1px solid #e5eaf0;
	color: #64748b;
	font-size: 13px;
	font-weight: 700;
	margin-bottom: 14px;
}

.function-empty i {
	color: #ee5a24;
	font-size: 16px;
}

.function-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 12px 0;
	border-bottom: 1px solid #edf0f5;
}

.function-item:last-of-type {
	border-bottom: none;
}

.function-item__label {
	display: flex;
	align-items: center;
	gap: 8px;
	color: #0f2236;
	font-size: 13px;
}

.function-item__label i {
	color: #16a34a;
	font-size: 17px;
}

.function-item__form {
	margin: 0;
}

.function-add-form {
	margin: 12px 0 0 0;
}

.function-add-row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 10px;
	align-items: stretch;
}

.function-add-row__select {
	min-width: 0;
	position: relative;
	z-index: 30;
}

.function-add-row__select .chosen-container {
	width: 100% !important;
}

.btn-function-add {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	min-height: 46px;
	padding: 0 18px;
	border: none;
	border-radius: 12px;
	background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%);
	color: #fff !important;
	font-weight: 900;
	font-size: 13px;
	box-shadow: 0 8px 18px rgba(238, 90, 36, .18);
	cursor: pointer;
	transition: all .18s ease;
	white-space: nowrap;
}

.btn-function-add:hover {
	transform: translateY(-1px);
	box-shadow: 0 10px 22px rgba(238, 90, 36, .25);
}

.btn-function-delete {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	min-height: 34px;
	padding: 0 12px;
	border: 1px solid #fecaca;
	border-radius: 10px;
	background: #fff1f2;
	color: #dc2626 !important;
	font-weight: 800;
	font-size: 12px;
	cursor: pointer;
	transition: all .18s ease;
}

.btn-function-delete:hover {
	background: #fee2e2;
	border-color: #fca5a5;
	color: #991b1b !important;
}

.function-group:has(.chosen-with-drop) {
	z-index: 100;
}

@media (max-width: 768px) {
	.function-add-row {
		grid-template-columns: 1fr;
	}

	.btn-function-add {
		width: 100%;
	}

	.function-item {
		align-items: flex-start;
		flex-direction: column;
	}

	.function-item__form,
	.btn-function-delete {
		width: 100%;
	}
}
/* ------------------------------
   Page club - activation joueurs
------------------------------ */

.activation-stats-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
	margin-bottom: 22px;
}

.activation-stat-card {
	position: relative;
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 16px;
	border-radius: 18px;
	background: #fff;
	border: 1px solid #edf0f5;
	box-shadow: 0 8px 24px rgba(31, 45, 61, 0.045);
	cursor: pointer;
	transition: all .18s ease;
	margin: 0;
}

.activation-stat-card:hover {
	transform: translateY(-1px);
	box-shadow: 0 12px 28px rgba(31, 45, 61, 0.07);
}

.activation-stat-card input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.activation-stat-card__icon {
	width: 42px;
	height: 42px;
	border-radius: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #f8fafc;
	color: #64748b;
	font-size: 22px;
	flex: 0 0 42px;
}

.activation-stat-card__content strong {
	display: block;
	font-size: 14px;
	font-weight: 900;
	color: #0f2236;
}

.activation-stat-card__content small {
	display: block;
	margin-top: 3px;
	font-size: 12px;
	font-weight: 700;
	color: #74788d;
}

.activation-stat-card:has(input:checked) {
	border-color: #ee5a24;
	background: #fff7ed;
	box-shadow: 0 12px 28px rgba(238, 90, 36, .12);
}

.activation-stat-card:has(input:checked) .activation-stat-card__icon {
	background: #ee5a24;
	color: #fff;
}

.activation-search-box {
	margin-bottom: 18px;
}

.activation-table-wrapper {
	width: 100%;
	overflow-x: auto;
	border: 1px solid #edf0f5;
	border-radius: 16px;
}

.activation-table {
	margin: 0;
	background: #fff;
}

.activation-table thead th {
	background: #f8fafc;
	color: #0f2236;
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	border-bottom: 1px solid #edf0f5;
	padding: 14px 16px;
	white-space: nowrap;
}

.activation-table tbody td {
	padding: 16px;
	vertical-align: middle;
	border-top: 1px solid #edf0f5;
}

.activation-player {
	display: flex;
	align-items: center;
	gap: 12px;
	min-width: 220px;
}

.activation-player__avatar {
	width: 42px;
	height: 42px;
	border-radius: 14px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 900;
	font-size: 13px;
	flex: 0 0 42px;
}

.activation-player strong {
	display: block;
	color: #0f2236;
	font-size: 14px;
	font-weight: 900;
}

.activation-player span {
	display: block;
	margin-top: 2px;
	color: #74788d;
	font-size: 12px;
	font-weight: 700;
}

.activation-suspended {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	margin-top: 6px;
	padding: 4px 8px;
	border-radius: 999px;
	background: #fee2e2;
	color: #991b1b;
	font-size: 11px;
	font-weight: 900;
}

.activation-status {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	min-width: 240px;
	padding: 12px;
	border-radius: 14px;
	border: 1px solid #edf0f5;
	background: #f8fafc;
}

.activation-status i {
	font-size: 20px;
	margin-top: 1px;
}

.activation-status strong {
	display: block;
	font-size: 13px;
	font-weight: 900;
	color: #0f2236;
}

.activation-status span {
	display: block;
	margin-top: 2px;
	font-size: 12px;
	font-weight: 600;
	color: #64748b;
	line-height: 1.35;
}

.activation-status--confirmed {
	background: #ecfdf5;
	border-color: #bbf7d0;
}

.activation-status--confirmed i {
	color: #16a34a;
}

.activation-status--pending {
	background: #fff7ed;
	border-color: #fed7aa;
}

.activation-status--pending i {
	color: #ee5a24;
}

.activation-status--inactive {
	background: #fff1f2;
	border-color: #fecaca;
}

.activation-status--inactive i {
	color: #dc2626;
}

.activation-old-status,
.activation-date {
	display: inline-flex;
	align-items: center;
	padding: 6px 10px;
	border-radius: 999px;
	background: #f8fafc;
	border: 1px solid #e5eaf0;
	color: #334155;
	font-size: 12px;
	font-weight: 800;
	white-space: nowrap;
}

.activation-muted {
	color: #94a3b8;
	font-weight: 700;
	font-size: 12px;
}

.activation-action-form {
	margin: 0;
}

.activation-confirm-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	min-height: 38px;
	padding: 0 14px;
	border: none;
	border-radius: 12px;
	background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%);
	color: #fff !important;
	font-size: 12px;
	font-weight: 900;
	box-shadow: 0 8px 18px rgba(238, 90, 36, .18);
	cursor: pointer;
	transition: all .18s ease;
	white-space: nowrap;
}

.activation-confirm-btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 10px 22px rgba(238, 90, 36, .25);
}

@media (max-width: 991px) {
	.activation-stats-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 576px) {
	.activation-stats-grid {
		grid-template-columns: 1fr;
	}
}
.activation-stats-grid--five {
	grid-template-columns: repeat(5, minmax(0, 1fr));
}

.activation-status--club-pending {
	background: #fff7ed;
	border-color: #fed7aa;
}

.activation-status--club-pending i {
	color: #ee5a24;
}

.activation-status--email-pending {
	background: #eff6ff;
	border-color: #bfdbfe;
}

.activation-status--email-pending i {
	color: #2563eb;
}

.activation-status--unknown {
	background: #f8fafc;
	border-color: #cbd5e1;
}

.activation-status--unknown i {
	color: #64748b;
}

.activation-stat-card--club:has(input:checked) {
	border-color: #ee5a24;
	background: #fff7ed;
}

.activation-stat-card--club:has(input:checked) .activation-stat-card__icon {
	background: #ee5a24;
	color: #fff;
}

.activation-stat-card--email:has(input:checked) {
	border-color: #2563eb;
	background: #eff6ff;
}

.activation-stat-card--email:has(input:checked) .activation-stat-card__icon {
	background: #2563eb;
	color: #fff;
}

@media (max-width: 1200px) {
	.activation-stats-grid--five {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 768px) {
	.activation-stats-grid--five {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 576px) {
	.activation-stats-grid--five {
		grid-template-columns: 1fr;
	}
}
/* ------------------------------
   Page activation club - résumé compact
------------------------------ */

.activation-player-summary {
	background: #ffffff;
	border: 1px solid #edf0f5;
	border-radius: 18px;
	box-shadow: 0 8px 30px rgba(31, 45, 61, 0.06);
	padding: 20px 24px;
	margin-bottom: 18px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
}

.activation-player-summary__main {
	display: flex;
	align-items: center;
	gap: 16px;
}

.activation-player-summary__avatar {
	width: 54px;
	height: 54px;
	border-radius: 16px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 17px;
	font-weight: 900;
	flex: 0 0 54px;
}

.activation-player-summary h3 {
	margin: 0;
	font-size: 20px;
	font-weight: 900;
	color: #0f2236;
}

.activation-player-summary p {
	margin: 5px 0 0 0;
	font-size: 13px;
	font-weight: 700;
	color: #74788d;
}

.activation-player-summary__badges {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 8px;
	flex-wrap: wrap;
}

.activation-player-summary__badges span {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 7px 10px;
	border-radius: 999px;
	background: #f8fafc;
	border: 1px solid #e5eaf0;
	color: #334155;
	font-size: 12px;
	font-weight: 800;
	white-space: nowrap;
}

.activation-player-summary__badges i {
	color: #ee5a24;
	font-size: 15px;
}

.activation-compact-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
	margin-bottom: 22px;
}

.activation-info-card {
	background: #ffffff;
	border: 1px solid #edf0f5;
	border-radius: 18px;
	box-shadow: 0 8px 24px rgba(31, 45, 61, 0.045);
	padding: 18px;
	display: flex;
	align-items: flex-start;
	gap: 14px;
	min-height: 150px;
}

.activation-info-card__icon {
	width: 40px;
	height: 40px;
	border-radius: 13px;
	background: rgba(238, 90, 36, .10);
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 21px;
	flex: 0 0 40px;
}

.activation-info-card h4 {
	margin: 0;
	font-size: 15px;
	font-weight: 900;
	color: #0f2236;
}

.activation-info-card p {
	margin: 8px 0 0 0;
	font-size: 13px;
	font-weight: 700;
	color: #334155;
	line-height: 1.55;
}

.activation-info-note {
	margin-top: 10px;
	padding: 8px 10px;
	border-radius: 12px;
	background: #fff7ed;
	border: 1px solid #fed7aa;
	color: #9a3412;
	font-size: 12px;
	font-weight: 800;
	line-height: 1.4;
}

@media (max-width: 1200px) {
	.activation-compact-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 768px) {
	.activation-player-summary {
		align-items: flex-start;
	}

	.activation-player-summary__badges {
		justify-content: flex-start;
	}

	.activation-player-summary__main {
		align-items: flex-start;
	}
}
/* ------------------------------
   Espace personnel joueur - Accueil
------------------------------ */

.player-home-page {
	padding-bottom: 30px;
}

.player-home-hero {
	margin-bottom: 18px;
}

.player-profile-summary {
	background: #ffffff;
	border: 1px solid #edf0f5;
	border-radius: 18px;
	box-shadow: 0 8px 30px rgba(31, 45, 61, 0.06);
	padding: 20px 24px;
	margin-bottom: 18px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
}

.player-profile-summary__main {
	display: flex;
	align-items: center;
	gap: 16px;
}

.player-profile-summary__avatar {
	width: 56px;
	height: 56px;
	border-radius: 16px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	font-weight: 900;
	flex: 0 0 56px;
}

.player-profile-summary h3 {
	margin: 0;
	font-size: 21px;
	font-weight: 900;
	color: #0f2236;
}

.player-profile-summary p {
	margin: 5px 0 0 0;
	font-size: 13px;
	font-weight: 700;
	color: #74788d;
}

.player-profile-summary__badges {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 8px;
	flex-wrap: wrap;
}

.player-profile-summary__badges span {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 7px 11px;
	border-radius: 999px;
	background: #f8fafc;
	border: 1px solid #e5eaf0;
	color: #334155;
	font-size: 12px;
	font-weight: 800;
	white-space: nowrap;
}

.player-profile-summary__badges i {
	color: #ee5a24;
	font-size: 15px;
}

.player-dashboard-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
	margin-bottom: 22px;
}

.player-dashboard-card {
	background: #ffffff;
	border: 1px solid #edf0f5;
	border-radius: 20px;
	box-shadow: 0 8px 28px rgba(31, 45, 61, 0.055);
	padding: 22px;
	display: flex;
	align-items: flex-start;
	gap: 16px;
	position: relative;
	overflow: hidden;
	min-height: 180px;
}

.player-dashboard-card::after {
	content: "";
	position: absolute;
	right: -50px;
	top: -50px;
	width: 150px;
	height: 150px;
	border-radius: 999px;
	background: rgba(238, 90, 36, .08);
}

.player-dashboard-card__icon {
	width: 54px;
	height: 54px;
	border-radius: 16px;
	background: rgba(238, 90, 36, .10);
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 28px;
	flex: 0 0 54px;
	position: relative;
	z-index: 1;
}

.player-dashboard-card__content {
	position: relative;
	z-index: 1;
	flex: 1;
}

.player-dashboard-card__content span {
	display: block;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: .04em;
	font-weight: 900;
	color: #74788d;
	margin-bottom: 6px;
}

.player-dashboard-card__content h3 {
	margin: 0;
	font-size: 34px;
	line-height: 1.1;
	font-weight: 900;
	color: #0f2236;
}

.player-dashboard-card__content p {
	margin: 8px 0 0 0;
	font-size: 13px;
	font-weight: 700;
	color: #64748b;
}

.player-dashboard-card__actions {
	margin-top: 18px;
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}
/* ------------------------------
   Espace personnel joueur - communiqués compact
------------------------------ */

.player-news-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.player-news-row {
	display: grid;
	grid-template-columns: 150px 1fr auto;
	align-items: center;
	gap: 16px;
	padding: 14px 16px;
	border: 1px solid #edf0f5;
	border-radius: 16px;
	background: #ffffff;
	text-decoration: none !important;
	transition: all .18s ease;
}

.player-news-row:hover {
	transform: translateY(-1px);
	box-shadow: 0 10px 24px rgba(31, 45, 61, 0.07);
	border-color: #fed7aa;
	background: #fffaf5;
}

.player-news-row__date {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	width: fit-content;
	padding: 7px 11px;
	border-radius: 999px;
	background: #fff7ed;
	border: 1px solid #fed7aa;
	color: #9a3412;
	font-size: 12px;
	font-weight: 900;
	white-space: nowrap;
}

.player-news-row__date i {
	color: #ee5a24;
	font-size: 15px;
}

.player-news-row__content h4 {
	margin: 0;
	color: #0f2236;
	font-size: 14px;
	line-height: 1.35;
	font-weight: 900;
}

.player-news-row__action {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: #ee5a24;
	font-size: 12px;
	font-weight: 900;
	white-space: nowrap;
}

.player-news-row__action i {
	font-size: 15px;
}

@media (max-width: 768px) {
	.player-news-row {
		grid-template-columns: 1fr;
		align-items: flex-start;
		gap: 10px;
	}

	.player-news-row__action {
		justify-content: flex-start;
	}
}

.player-alert-card {
	margin-bottom: 18px;
}

.player-alert-card--danger {
	border-color: #fecaca;
}

.player-alert-card--danger .affiliation-card__icon {
	background: #fff1f2;
	color: #dc2626;
}

.player-suspension-content h4 {
	margin: 0;
	font-size: 18px;
	font-weight: 900;
	color: #991b1b;
}

.player-suspension-content p {
	margin: 8px 0 0 0;
	font-size: 13px;
	font-weight: 700;
	color: #7f1d1d;
}

.player-suspension-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
	margin-top: 18px;
}

.player-suspension-grid div {
	background: #fff7f7;
	border: 1px solid #fecaca;
	border-radius: 14px;
	padding: 12px;
}

.player-suspension-grid strong {
	display: block;
	font-size: 12px;
	font-weight: 900;
	color: #7f1d1d;
	margin-bottom: 5px;
}

.player-suspension-grid span {
	display: block;
	font-size: 13px;
	font-weight: 800;
	color: #334155;
}

.player-actions-inline {
	padding: 18px 0 0 0;
	justify-content: flex-start;
}

@media (max-width: 991px) {
	.player-dashboard-grid,
	.player-suspension-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 768px) {
	.player-profile-summary {
		align-items: flex-start;
	}

	.player-profile-summary__badges {
		justify-content: flex-start;
	}

	.player-profile-summary__main {
		align-items: flex-start;
	}

	.player-dashboard-card {
		flex-direction: column;
	}
}
/* ------------------------------
   Annonces importantes joueur
------------------------------ */

.player-important-news {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	padding: 22px 24px;
	margin-bottom: 18px;
	border-radius: 20px;
	background: #fff7ed;
	border: 1px solid #fed7aa;
	box-shadow: 0 10px 30px rgba(238, 90, 36, 0.08);
}

.player-important-news__icon {
	width: 48px;
	height: 48px;
	border-radius: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
	flex: 0 0 48px;
	background: #ffedd5;
	color: #ee5a24;
}

.player-important-news__content h3 {
	margin: 0;
	font-size: 19px;
	font-weight: 900;
	color: #0f2236;
}
.player-important-news__content {
	max-width: 1050px;
}
.player-important-news__subtitle {
	margin: 5px 0 0 0;
	font-size: 13px;
	font-weight: 800;
	color: #9a3412;
}
.player-important-news__text strong {
	color: #0f2236;
	font-weight: 900;
}
.player-important-news__text p:last-child {
	margin-bottom: 0;
}
.player-important-news__text {
	margin-top: 14px;
	font-size: 14px;
	font-weight: 650;
	color: #334155;
	line-height: 1.7;
}

.player-important-news__text p {
	margin: 0 0 12px 0;
}

.player-important-news--orange {
	border-color: #fed7aa;
	background: #fff7ed;
}

.player-important-news--orange .player-important-news__icon {
	background: #ffedd5;
	color: #ee5a24;
}

.player-important-news--bleu {
	border-color: #bfdbfe;
	background: #eff6ff;
}

.player-important-news--bleu .player-important-news__icon {
	background: #dbeafe;
	color: #2563eb;
}

.player-important-news--vert {
	border-color: #bbf7d0;
	background: #ecfdf5;
}

.player-important-news--vert .player-important-news__icon {
	background: #dcfce7;
	color: #16a34a;
}

.player-important-news--rouge {
	border-color: #fecaca;
	background: #fff1f2;
}

.player-important-news--rouge .player-important-news__icon {
	background: #fee2e2;
	color: #dc2626;
}

.player-important-news--gris {
	border-color: #e5e7eb;
	background: #f8fafc;
}

.player-important-news--gris .player-important-news__icon {
	background: #e5e7eb;
	color: #475569;
}

@media (max-width: 768px) {
	.player-important-news {
		flex-direction: column;
	}
}
/* ------------------------------
   Gestion employé - annonces importantes
------------------------------ */

.annonce-editor-toolbar {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	margin-bottom: 10px;
}

.annonce-editor-toolbar button {
	border: 1px solid #edf0f5;
	background: #ffffff;
	color: #0f2236;
	font-size: 12px;
	font-weight: 900;
	padding: 8px 11px;
	border-radius: 10px;
	cursor: pointer;
	transition: all .18s ease;
}

.annonce-editor-toolbar button:hover {
	background: #fff7ed;
	border-color: #fed7aa;
	color: #ee5a24;
}

.annonce-content-textarea {
	min-height: 180px;
	font-family: Consolas, Monaco, monospace;
	font-size: 13px;
	line-height: 1.5;
}

.annonce-status {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 6px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 900;
	white-space: nowrap;
}

.annonce-status--online {
	background: #ecfdf5;
	color: #16a34a;
	border: 1px solid #bbf7d0;
}

.annonce-status--offline {
	background: #f8fafc;
	color: #64748b;
	border: 1px solid #e5eaf0;
}

.annonce-color-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 6px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 900;
	white-space: nowrap;
}

.annonce-color-badge--orange {
	background: #fff7ed;
	color: #9a3412;
	border: 1px solid #fed7aa;
}

.annonce-color-badge--bleu {
	background: #eff6ff;
	color: #1d4ed8;
	border: 1px solid #bfdbfe;
}

.annonce-color-badge--vert {
	background: #ecfdf5;
	color: #15803d;
	border: 1px solid #bbf7d0;
}

.annonce-color-badge--rouge {
	background: #fff1f2;
	color: #be123c;
	border: 1px solid #fecaca;
}

.annonce-color-badge--gris {
	background: #f8fafc;
	color: #475569;
	border: 1px solid #e5eaf0;
}

.annonce-actions {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 8px;
	flex-wrap: wrap;
}

.activation-delete-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	min-height: 38px;
	padding: 0 14px;
	border: none;
	border-radius: 12px;
	background: #fee2e2;
	color: #b91c1c !important;
	font-size: 12px;
	font-weight: 900;
	cursor: pointer;
	transition: all .18s ease;
	white-space: nowrap;
}

.activation-delete-btn:hover {
	background: #fecaca;
	transform: translateY(-1px);
}
/* =========================================================
   MOBILE - Espace connecté EP
   Header + menu gauche + menu supérieur + topbar
   ========================================================= */

@media (max-width: 1024px) {

	html,
	body {
		width: 100%;
		min-height: 100%;
		background: #eef8f7 !important;
		overflow-x: hidden !important;
	}

	/* Header mobile */
	.modern-mobile-header,
	.kt-header-mobile {
		height: 64px !important;
		min-height: 64px !important;
		max-height: 64px !important;
		width: 100% !important;
		padding: 0 12px !important;
		background: #08131d !important;
		box-shadow: 0 8px 22px rgba(15, 34, 54, .18) !important;
		display: grid !important;
		grid-template-columns: 76px 1fr 90px !important;
		align-items: center !important;
		position: fixed !important;
		top: 0 !important;
		left: 0 !important;
		right: 0 !important;
		z-index: 1400 !important;
		overflow: hidden !important;
	}

	.modern-mobile-header__side {
		display: flex !important;
		align-items: center !important;
		height: 64px !important;
		min-width: 0 !important;
	}

	.modern-mobile-header__side--left {
		justify-content: flex-start !important;
	}

	.modern-mobile-header__side--right {
		justify-content: flex-end !important;
		gap: 8px !important;
	}

	.modern-mobile-header__center {
		height: 64px !important;
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		min-width: 0 !important;
		overflow: hidden !important;
	}

	.modern-mobile-logo-link {
		height: 64px !important;
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		gap: 8px !important;
		text-decoration: none !important;
		max-width: 100% !important;
		overflow: hidden !important;
	}

	.modern-mobile-logo-img {
		width: auto !important;
		height: auto !important;
		max-height: 42px !important;
		max-width: 54px !important;
		object-fit: contain !important;
		display: block !important;
		flex: 0 0 auto !important;
	}

	.modern-mobile-logo-link span {
		display: block !important;
		font-size: 11px !important;
		font-weight: 900 !important;
		color: #ffffff !important;
		line-height: 1.1 !important;
		white-space: nowrap !important;
		overflow: hidden !important;
		text-overflow: ellipsis !important;
		max-width: 105px !important;
	}

	.modern-mobile-btn,
	.kt-header-mobile__toolbar-toggler,
	.kt-header-mobile__toolbar-topbar-toggler {
		width: 34px !important;
		height: 34px !important;
		min-width: 34px !important;
		min-height: 34px !important;
		padding: 0 !important;
		margin: 0 !important;
		border: 0 !important;
		border-radius: 11px !important;
		background: rgba(255, 255, 255, .08) !important;
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		position: relative !important;
		cursor: pointer !important;
	}

	.modern-mobile-btn--burger span,
	.modern-mobile-btn--burger span::before,
	.modern-mobile-btn--burger span::after,
	.kt-header-mobile__toolbar-toggler span,
	.kt-header-mobile__toolbar-toggler span::before,
	.kt-header-mobile__toolbar-toggler span::after {
		display: block !important;
		width: 16px !important;
		height: 2px !important;
		border-radius: 999px !important;
		background: #ffffff !important;
		position: relative !important;
		content: "" !important;
	}

	.modern-mobile-btn--burger span::before,
	.kt-header-mobile__toolbar-toggler span::before {
		position: absolute !important;
		top: -6px !important;
		left: 0 !important;
	}

	.modern-mobile-btn--burger span::after,
	.kt-header-mobile__toolbar-toggler span::after {
		position: absolute !important;
		top: 6px !important;
		left: 0 !important;
	}

	.modern-mobile-btn--dots i,
	.kt-header-mobile__toolbar-topbar-toggler i {
		color: #ffffff !important;
		font-size: 20px !important;
		line-height: 1 !important;
	}

	/* Page sous le header */
	.kt-header-mobile--fixed .kt-page {
		padding-top: 64px !important;
	}

	.kt-wrapper {
		padding-top: 0 !important;
	}

	.kt-content {
		padding-top: 12px !important;
		background: #eef8f7 !important;
	}

	.kt-subheader {
		display: none !important;
	}

	.kt-container,
	.kt-container--fluid {
		padding-left: 14px !important;
		padding-right: 14px !important;
	}

	.affiliation-page,
	.player-home-page {
		width: 100% !important;
		max-width: 100% !important;
		margin: 0 !important;
		padding: 0 0 24px 0 !important;
	}

	/* Header desktop conservé uniquement comme conteneur des menus */
	.kt-header {
		display: block !important;
		position: fixed !important;
		top: 0 !important;
		left: 0 !important;
		right: 0 !important;
		height: 0 !important;
		min-height: 0 !important;
		background: transparent !important;
		box-shadow: none !important;
		z-index: 1300 !important;
		pointer-events: none !important;
	}

	/* Menu gauche */
	#kt_aside {
		position: fixed !important;
		top: 0 !important;
		left: 0 !important;
		right: auto !important;
		bottom: 0 !important;
		width: 285px !important;
		max-width: 85vw !important;
		height: 100vh !important;
		min-height: 100vh !important;
		z-index: 1502 !important;
		background: #0d2236 !important;
		box-shadow: 16px 0 40px rgba(8, 19, 29, .35) !important;
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
		transform: translateX(-105%) !important;
		transition: transform .24s ease !important;
		overflow-y: auto !important;
		overflow-x: hidden !important;
	}

	body.mobile-aside-open #kt_aside,
	#kt_aside.modern-aside-open {
		transform: translateX(0) !important;
	}

	/* Menu supérieur : panneau droit */
	#kt_header_menu_wrapper,
	.kt-header-menu-wrapper {
		position: fixed !important;
		top: 0 !important;
		right: 0 !important;
		left: auto !important;
		bottom: 0 !important;
		width: 285px !important;
		max-width: 85vw !important;
		height: 100vh !important;
		background: #0d2236 !important;
		box-shadow: -16px 0 40px rgba(8, 19, 29, .35) !important;
		z-index: 1502 !important;
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
		transform: translateX(105%) !important;
		transition: transform .24s ease !important;
		overflow-y: auto !important;
		overflow-x: hidden !important;
		padding: 18px 0 !important;
		pointer-events: auto !important;
	}

	body.mobile-header-menu-open #kt_header_menu_wrapper,
	body.mobile-header-menu-open .kt-header-menu-wrapper,
	#kt_header_menu_wrapper.modern-header-menu-open,
	.kt-header-menu-wrapper.modern-header-menu-open {
		transform: translateX(0) !important;
	}

	#kt_header_menu_wrapper .kt-header-menu,
	.kt-header-menu-wrapper .kt-header-menu {
		background: transparent !important;
		box-shadow: none !important;
	}

	#kt_header_menu_wrapper .kt-menu__nav,
	.kt-header-menu-wrapper .kt-menu__nav {
		display: flex !important;
		flex-direction: column !important;
		padding: 0 12px !important;
		margin: 0 !important;
	}

	#kt_header_menu_wrapper .kt-menu__item,
	.kt-header-menu-wrapper .kt-menu__item {
		width: 100% !important;
		margin-bottom: 8px !important;
	}

	#kt_header_menu_wrapper .kt-menu__link,
	.kt-header-menu-wrapper .kt-menu__link {
		min-height: 44px !important;
		border-radius: 14px !important;
		padding: 0 14px !important;
		background: rgba(255,255,255,.05) !important;
		color: #ffffff !important;
		display: flex !important;
		align-items: center !important;
	}

	#kt_header_menu_wrapper .kt-menu__link-text,
	.kt-header-menu-wrapper .kt-menu__link-text {
		color: #ffffff !important;
		font-weight: 800 !important;
	}

	#kt_header_menu_wrapper .kt-menu__link-icon,
	.kt-header-menu-wrapper .kt-menu__link-icon,
	#kt_header_menu_wrapper i,
	.kt-header-menu-wrapper i {
		color: #ff8a00 !important;
	}

	#kt_header_menu_wrapper .kt-menu__submenu,
	.kt-header-menu-wrapper .kt-menu__submenu {
		position: static !important;
		width: 100% !important;
		box-shadow: none !important;
		background: rgba(255,255,255,.04) !important;
		border-radius: 14px !important;
		margin-top: 6px !important;
		padding: 8px !important;
	}

	/* Topbar utilisateur */
	.kt-header__topbar {
		display: none !important;
		position: fixed !important;
		top: 76px !important;
		left: 14px !important;
		right: 14px !important;
		background: #ffffff !important;
		border-radius: 18px !important;
		box-shadow: 0 18px 45px rgba(15, 34, 54, .22) !important;
		padding: 14px !important;
		z-index: 1502 !important;
		pointer-events: auto !important;
	}

	body.mobile-topbar-open .kt-header__topbar,
	.kt-header__topbar.modern-topbar-open {
		display: flex !important;
		align-items: center !important;
		justify-content: flex-end !important;
		gap: 12px !important;
	}

	/* Backdrop commun */
	.mobile-aside-backdrop {
		position: fixed !important;
		inset: 0 !important;
		z-index: 1501 !important;
		background: rgba(8, 19, 29, .58) !important;
		backdrop-filter: blur(2px) !important;
	}

	body.mobile-aside-open,
	body.mobile-header-menu-open,
	body.mobile-topbar-open {
		overflow: hidden !important;
	}

	#kt_aside_close_btn {
		position: fixed !important;
		top: 14px !important;
		left: 298px !important;
		z-index: 1503 !important;
		width: 36px !important;
		height: 36px !important;
		border-radius: 12px !important;
		background: #ffffff !important;
		color: #0f2236 !important;
		display: none !important;
		align-items: center !important;
		justify-content: center !important;
		box-shadow: 0 8px 20px rgba(15, 34, 54, .18) !important;
		border: none !important;
	}

	body.mobile-aside-open #kt_aside_close_btn {
		display: flex !important;
	}

	#kt_aside_close_btn i {
		color: #0f2236 !important;
		font-size: 20px !important;
	}
}

/* Mobile très étroit */
@media (max-width: 420px) {

	.modern-mobile-header {
		grid-template-columns: 58px 1fr 82px !important;
		padding: 0 10px !important;
	}

	.modern-mobile-logo-img {
		max-height: 40px !important;
		max-width: 50px !important;
	}

	.modern-mobile-logo-link span {
		font-size: 10px !important;
		max-width: 92px !important;
	}

	.modern-mobile-btn {
		width: 32px !important;
		height: 32px !important;
		min-width: 32px !important;
		min-height: 32px !important;
	}

	#kt_aside,
	#kt_header_menu_wrapper,
	.kt-header-menu-wrapper {
		width: 270px !important;
		max-width: 84vw !important;
	}

	#kt_aside_close_btn {
		left: 282px !important;
	}
}

/* Page accueil joueur - mobile */
@media (max-width: 768px) {

	.affiliation-hero {
		padding: 20px !important;
		border-radius: 18px !important;
		margin-bottom: 16px !important;
	}

	.affiliation-hero h2 {
		font-size: 21px !important;
		line-height: 1.2 !important;
	}

	.affiliation-hero p {
		font-size: 13px !important;
		line-height: 1.5 !important;
	}

	.player-profile-summary {
		padding: 18px !important;
		border-radius: 18px !important;
		margin-bottom: 16px !important;
		align-items: flex-start !important;
	}

	.player-profile-summary__main {
		width: 100% !important;
		align-items: flex-start !important;
	}

	.player-profile-summary h3 {
		font-size: 18px !important;
		line-height: 1.2 !important;
	}

	.player-profile-summary p {
		font-size: 12px !important;
		line-height: 1.4 !important;
	}

	.player-profile-summary__badges {
		width: 100% !important;
		justify-content: flex-start !important;
	}

	.player-profile-summary__badges span {
		font-size: 11px !important;
	}

	.player-dashboard-grid {
		grid-template-columns: 1fr !important;
		gap: 14px !important;
		margin-bottom: 16px !important;
	}

	.player-dashboard-card {
		min-height: auto !important;
		padding: 20px !important;
		border-radius: 18px !important;
		flex-direction: column !important;
	}

	.player-dashboard-card__content h3 {
		font-size: 28px !important;
	}

	.player-important-news {
		padding: 18px !important;
		border-radius: 18px !important;
		margin-bottom: 16px !important;
		flex-direction: column !important;
	}

	.player-important-news__content h3 {
		font-size: 17px !important;
		line-height: 1.25 !important;
	}

	.player-important-news__subtitle {
		font-size: 12px !important;
	}

	.player-important-news__text {
		font-size: 13px !important;
		line-height: 1.65 !important;
	}

	.affiliation-card {
		border-radius: 18px !important;
		margin-bottom: 16px !important;
	}

	.affiliation-card__header,
	.affiliation-card__body {
		padding: 18px !important;
	}

	.player-news-row {
		grid-template-columns: 1fr !important;
		align-items: flex-start !important;
		gap: 10px !important;
	}
}
@media (max-width: 1024px) {
	body:not(.mobile-topbar-open) .kt-header__topbar {
		display: none !important;
		visibility: hidden !important;
		opacity: 0 !important;
		pointer-events: none !important;
	}

	body.mobile-topbar-open .kt-header__topbar {
		display: flex !important;
		visibility: visible !important;
		opacity: 1 !important;
		pointer-events: auto !important;
	}

	body:not(.mobile-header-menu-open) #kt_header_menu_wrapper,
	body:not(.mobile-header-menu-open) .kt-header-menu-wrapper {
		transform: translateX(105%) !important;
	}

	body:not(.mobile-aside-open) #kt_aside {
		transform: translateX(-105%) !important;
	}
}
/* =========================================================
   Ajustement final menu supérieur mobile
   ========================================================= */

@media (max-width: 1024px) {

	/* Le header mobile reste toujours au-dessus du voile */
	.modern-mobile-header,
	.kt-header-mobile {
		z-index: 1600 !important;
	}

	/* Le voile commence sous le header */
	.mobile-aside-backdrop {
		top: 64px !important;
		z-index: 1500 !important;
		background: rgba(8, 19, 29, .55) !important;
		backdrop-filter: blur(3px) !important;
	}

	/* Menu supérieur à droite, sous le header */
	#kt_header_menu_wrapper,
	.kt-header-menu-wrapper {
		top: 64px !important;
		height: calc(100vh - 64px) !important;
		width: 300px !important;
		max-width: 82vw !important;
		z-index: 1502 !important;
		padding: 18px 12px !important;
		background: #0d2236 !important;
		border-radius: 0 !important;
	}

	body.mobile-header-menu-open #kt_header_menu_wrapper,
	body.mobile-header-menu-open .kt-header-menu-wrapper,
	#kt_header_menu_wrapper.modern-header-menu-open,
	.kt-header-menu-wrapper.modern-header-menu-open {
		transform: translateX(0) !important;
	}

	/* Menu gauche aussi sous le header, si tu préfères garder le header visible */
	#kt_aside {
		top: 64px !important;
		height: calc(100vh - 64px) !important;
		z-index: 1502 !important;
	}

	#kt_aside_close_btn {
		top: 76px !important;
		z-index: 1503 !important;
	}

	/* Amélioration lisibilité des items du menu supérieur */
	#kt_header_menu_wrapper .kt-menu__item,
	.kt-header-menu-wrapper .kt-menu__item {
		margin-bottom: 10px !important;
	}

	#kt_header_menu_wrapper .kt-menu__link,
	.kt-header-menu-wrapper .kt-menu__link {
		min-height: 52px !important;
		border-radius: 16px !important;
		padding: 0 16px !important;
		background: rgba(255,255,255,.055) !important;
		border: 1px solid rgba(255,255,255,.035) !important;
	}

	#kt_header_menu_wrapper .kt-menu__link:hover,
	.kt-header-menu-wrapper .kt-menu__link:hover {
		background: rgba(255,255,255,.09) !important;
	}

	#kt_header_menu_wrapper .kt-menu__link-text,
	.kt-header-menu-wrapper .kt-menu__link-text {
		font-size: 13px !important;
		font-weight: 900 !important;
		color: #ffffff !important;
	}

	#kt_header_menu_wrapper .kt-menu__link-icon,
	.kt-header-menu-wrapper .kt-menu__link-icon,
	#kt_header_menu_wrapper i,
	.kt-header-menu-wrapper i {
		color: #ff8a00 !important;
	}
}
/* =========================================================
   Ajustement lisibilité menu supérieur mobile
   ========================================================= */

@media (max-width: 1024px) {

	.mobile-aside-backdrop {
		top: 64px !important;
		z-index: 1500 !important;
		background: rgba(8, 19, 29, .42) !important;
		backdrop-filter: blur(1.5px) !important;
		-webkit-backdrop-filter: blur(1.5px) !important;
	}

	#kt_header_menu_wrapper,
	.kt-header-menu-wrapper {
		top: 64px !important;
		right: 0 !important;
		height: calc(100vh - 64px) !important;
		width: 300px !important;
		max-width: 82vw !important;
		z-index: 1505 !important;
		background: #0b1f31 !important;
		box-shadow: -14px 0 35px rgba(8, 19, 29, .32) !important;
		filter: none !important;
		backdrop-filter: none !important;
		-webkit-backdrop-filter: none !important;
	}

	body.mobile-header-menu-open #kt_header_menu_wrapper,
	body.mobile-header-menu-open .kt-header-menu-wrapper,
	#kt_header_menu_wrapper.modern-header-menu-open,
	.kt-header-menu-wrapper.modern-header-menu-open {
		transform: translateX(0) !important;
		filter: none !important;
	}

	#kt_header_menu_wrapper .kt-menu__link,
	.kt-header-menu-wrapper .kt-menu__link {
		background: rgba(255, 255, 255, .07) !important;
		border: 1px solid rgba(255, 255, 255, .06) !important;
		box-shadow: none !important;
	}

	#kt_header_menu_wrapper .kt-menu__link-text,
	.kt-header-menu-wrapper .kt-menu__link-text {
		color: #ffffff !important;
		text-shadow: none !important;
		opacity: 1 !important;
	}

	#kt_header_menu_wrapper .kt-menu__item.kt-menu__item--active > .kt-menu__link,
	.kt-header-menu-wrapper .kt-menu__item.kt-menu__item--active > .kt-menu__link {
		background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%) !important;
	}
}
@media (max-width: 420px) {
	#kt_header_menu_wrapper,
	.kt-header-menu-wrapper {
		width: 285px !important;
		max-width: 80vw !important;
	}
}
/* =========================================================
   Correction : le voile passe derrière le menu supérieur
   ========================================================= */

@media (max-width: 1024px) {

	/* Le header desktop sert de conteneur au menu supérieur.
	   Il doit être au-dessus du voile. */
	.kt-header {
		z-index: 1506 !important;
		pointer-events: none !important;
	}

	/* Le header mobile reste tout au-dessus */
	.modern-mobile-header,
	.kt-header-mobile {
		z-index: 1600 !important;
	}

	/* Le voile est sous les menus */
	.mobile-aside-backdrop {
		top: 64px !important;
		z-index: 1500 !important;
		background: rgba(8, 19, 29, .50) !important;
		backdrop-filter: blur(2px) !important;
		-webkit-backdrop-filter: blur(2px) !important;
	}

	/* Le menu supérieur passe au-dessus du voile */
	#kt_header_menu_wrapper,
	.kt-header-menu-wrapper {
		z-index: 1507 !important;
		filter: none !important;
		backdrop-filter: none !important;
		-webkit-backdrop-filter: none !important;
		pointer-events: auto !important;
		background: #0d2236 !important;
	}

	/* Sécurité : aucun enfant du menu ne doit être flouté */
	#kt_header_menu_wrapper *,
	.kt-header-menu-wrapper * {
		filter: none !important;
		backdrop-filter: none !important;
		-webkit-backdrop-filter: none !important;
	}
}
/* =========================================================
   Correction affichage sous-menu mobile supérieur
   ========================================================= */

@media (max-width: 1024px) {

	/* Conteneur du sous-menu */
	#kt_header_menu_wrapper .kt-menu__submenu,
	.kt-header-menu-wrapper .kt-menu__submenu {
		position: static !important;
		display: block !important;
		width: 100% !important;
		margin: 10px 0 12px 0 !important;
		padding: 10px !important;
		border-radius: 18px !important;
		background: rgba(255, 255, 255, .055) !important;
		box-shadow: none !important;
		border: 1px solid rgba(255, 255, 255, .05) !important;
		overflow: visible !important;
	}

	/* Liste interne du sous-menu */
	#kt_header_menu_wrapper .kt-menu__subnav,
	.kt-header-menu-wrapper .kt-menu__subnav {
		display: flex !important;
		flex-direction: column !important;
		gap: 10px !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	/* Items du sous-menu */
	#kt_header_menu_wrapper .kt-menu__submenu .kt-menu__item,
	.kt-header-menu-wrapper .kt-menu__submenu .kt-menu__item {
		margin: 0 !important;
		width: 100% !important;
	}

	/* Liens du sous-menu */
	#kt_header_menu_wrapper .kt-menu__submenu .kt-menu__link,
	.kt-header-menu-wrapper .kt-menu__submenu .kt-menu__link {
		min-height: 58px !important;
		padding: 10px 14px !important;
		border-radius: 16px !important;
		background: rgba(255, 255, 255, .105) !important;
		border: 1px solid rgba(255, 255, 255, .08) !important;
		display: flex !important;
		align-items: center !important;
		gap: 12px !important;
		color: #ffffff !important;
		opacity: 1 !important;
	}

	/* Icône du sous-menu */
	#kt_header_menu_wrapper .kt-menu__submenu .kt-menu__link-icon,
	.kt-header-menu-wrapper .kt-menu__submenu .kt-menu__link-icon,
	#kt_header_menu_wrapper .kt-menu__submenu .kt-menu__link i,
	.kt-header-menu-wrapper .kt-menu__submenu .kt-menu__link i {
		width: 42px !important;
		height: 42px !important;
		min-width: 42px !important;
		border-radius: 14px !important;
		background: #fff4ec !important;
		color: #ee5a24 !important;
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		font-size: 20px !important;
		margin: 0 !important;
	}

	/* Texte du sous-menu */
	#kt_header_menu_wrapper .kt-menu__submenu .kt-menu__link-text,
	.kt-header-menu-wrapper .kt-menu__submenu .kt-menu__link-text {
		color: #ffffff !important;
		font-size: 14px !important;
		font-weight: 900 !important;
		line-height: 1.25 !important;
		opacity: 1 !important;
		text-shadow: none !important;
	}

	/* Hover */
	#kt_header_menu_wrapper .kt-menu__submenu .kt-menu__link:hover,
	.kt-header-menu-wrapper .kt-menu__submenu .kt-menu__link:hover {
		background: rgba(255, 255, 255, .15) !important;
		border-color: rgba(255, 138, 0, .35) !important;
	}

	/* Badge type 0 - 1 */
	#kt_header_menu_wrapper .kt-menu__submenu .kt-badge,
	.kt-header-menu-wrapper .kt-menu__submenu .kt-badge,
	#kt_header_menu_wrapper .kt-menu__submenu .badge,
	.kt-header-menu-wrapper .kt-menu__submenu .badge {
		background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%) !important;
		color: #ffffff !important;
		border-radius: 999px !important;
		font-size: 12px !important;
		font-weight: 900 !important;
		padding: 6px 10px !important;
		min-width: 48px !important;
		text-align: center !important;
	}

	/* Flèche éventuelle à droite */
	#kt_header_menu_wrapper .kt-menu__submenu .kt-menu__ver-arrow,
	.kt-header-menu-wrapper .kt-menu__submenu .kt-menu__ver-arrow,
	#kt_header_menu_wrapper .kt-menu__submenu .kt-menu__hor-arrow,
	.kt-header-menu-wrapper .kt-menu__submenu .kt-menu__hor-arrow {
		color: rgba(255,255,255,.75) !important;
	}
}
/* =========================================================
   Annuaire moderne
   ========================================================= */

.annuaire-modern-page a {
	color: #ee5a24;
	font-weight: 800;
}

.annuaire-club-select {
	width: min(520px, 100%);
}

.annuaire-search-form {
	display: flex;
	align-items: center;
	gap: 12px;
	width: 100%;
}

.annuaire-search-form .chosen-container,
.annuaire-search-form select {
	flex: 1;
	min-width: 0;
}

.annuaire-club-summary {
	margin-bottom: 18px;
}

.annuaire-dashboard-grid {
	margin-bottom: 18px;
}

.annuaire-info-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-top: 18px;
}

.annuaire-info-list div {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	padding: 10px 0;
	border-bottom: 1px solid rgba(15, 34, 54, .08);
}

.annuaire-info-list div:last-child {
	border-bottom: 0;
}

.annuaire-info-list strong {
	color: #071b33;
	font-weight: 900;
	font-size: 13px;
}

.annuaire-info-list span {
	color: #6f7d95;
	font-weight: 700;
	text-align: right;
	font-size: 13px;
}

.annuaire-info-list--compact {
	margin-top: 14px;
}

.annuaire-stat-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 10px;
	margin-top: 18px;
}

.annuaire-stat-grid div {
	background: #fff4ec;
	border: 1px solid #ffd4b4;
	border-radius: 16px;
	padding: 14px 10px;
	text-align: center;
}

.annuaire-stat-grid strong {
	display: block;
	color: #ee5a24;
	font-size: 24px;
	font-weight: 900;
	line-height: 1;
}

.annuaire-stat-grid span {
	display: block;
	margin-top: 6px;
	color: #6f7d95;
	font-size: 11px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .04em;
}

.annuaire-grid-two {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px;
	margin-bottom: 18px;
}

.annuaire-location-card {
	padding: 18px;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	margin-bottom: 14px;
	background: #fff;
}

.annuaire-location-card:last-child {
	margin-bottom: 0;
}

.annuaire-location-card h4 {
	margin: 0;
	font-size: 17px;
	font-weight: 900;
	color: #071b33;
}

.annuaire-responsables-list {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.annuaire-responsable-card {
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 16px;
	display: grid;
	grid-template-columns: 54px 1fr auto;
	gap: 14px;
	align-items: center;
	background: #fff;
}

.annuaire-responsable-avatar {
	width: 54px;
	height: 54px;
	border-radius: 16px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 900;
	font-size: 16px;
}

.annuaire-responsable-content strong {
	display: block;
	color: #071b33;
	font-size: 15px;
	font-weight: 900;
	margin-bottom: 8px;
}

.annuaire-role {
	display: inline-flex;
	background: #fff4ec;
	color: #ee5a24;
	border-radius: 999px;
	padding: 5px 10px;
	font-size: 11px;
	font-weight: 900;
	margin-bottom: 8px;
}

.annuaire-contact-line {
	display: flex;
	align-items: center;
	gap: 8px;
	color: #6f7d95;
	font-weight: 700;
	font-size: 13px;
	margin-top: 4px;
}

.annuaire-contact-line i {
	color: #ee5a24;
	font-size: 16px;
}

.annuaire-filter-row {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 18px;
}

.annuaire-filter-row label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 999px;
	padding: 9px 13px;
	color: #071b33;
	font-weight: 800;
	font-size: 12px;
	cursor: pointer;
}

.annuaire-filter-row input {
	accent-color: #ee5a24;
}

.annuaire-status {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 46px;
	border-radius: 999px;
	padding: 6px 10px;
	font-size: 11px;
	font-weight: 900;
	background: #edf1f7;
	color: #071b33;
}

.annuaire-status--jo {
	background: #e8fff6;
	color: #087f5b;
}

.annuaire-status--nj {
	background: #fff4ec;
	color: #ee5a24;
}

.annuaire-status--lr {
	background: #eef4ff;
	color: #2457c5;
}

.annuaire-status--ji {
	background: #f3e8ff;
	color: #7e22ce;
}

.annuaire-status--sd {
	background: #fff7d6;
	color: #9a6700;
}

.annuaire-status--an {
	background: #f1f5f9;
	color: #64748b;
}

@media (max-width: 991px) {
	.annuaire-grid-two {
		grid-template-columns: 1fr;
	}

	.annuaire-search-form {
		flex-direction: column;
		align-items: stretch;
	}

	.annuaire-stat-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.annuaire-responsable-card {
		grid-template-columns: 54px 1fr;
	}

	.annuaire-responsable-card .activation-confirm-btn {
		grid-column: 1 / -1;
		width: 100%;
		justify-content: center;
	}
}

@media (max-width: 600px) {
	.annuaire-info-list div {
		flex-direction: column;
		gap: 4px;
	}

	.annuaire-info-list span {
		text-align: left;
	}

	.annuaire-stat-grid {
		grid-template-columns: 1fr 1fr;
	}

	.annuaire-filter-row label {
		width: 100%;
	}
}
/* =========================================================
   Championnats de Belgique - Simples
   ========================================================= */

.cb-modern-page {
	max-width: 1180px;
	margin: 0 auto;
}

.cb-inscriptions-list {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.cb-inscription-card {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 22px;
	padding: 20px;
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 20px;
	align-items: center;
	box-shadow: 0 10px 30px rgba(15, 34, 54, .05);
	transition: .2s ease;
}

.cb-inscription-card:hover {
	border-color: rgba(238, 90, 36, .25);
	box-shadow: 0 14px 36px rgba(15, 34, 54, .08);
	transform: translateY(-1px);
}

.cb-inscription-main {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	min-width: 0;
}

.cb-inscription-icon {
	width: 58px;
	height: 58px;
	border-radius: 18px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 28px;
	flex: 0 0 auto;
}

.cb-inscription-content {
	min-width: 0;
}

.cb-category-label {
	display: inline-flex;
	align-items: center;
	padding: 5px 10px;
	border-radius: 999px;
	background: #fff4ec;
	color: #ee5a24;
	font-size: 11px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 8px;
}

.cb-inscription-content h4 {
	margin: 0;
	color: #071b33;
	font-size: 20px;
	font-weight: 900;
	line-height: 1.25;
}

.cb-inscription-content p {
	margin: 6px 0 0 0;
	color: #6f7d95;
	font-size: 13px;
	font-weight: 700;
}

.cb-player-line {
	margin-top: 12px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: #071b33;
	font-size: 14px;
}

.cb-player-line i {
	color: #ee5a24;
	font-size: 18px;
}

.cb-inscription-side {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 10px;
	min-width: 260px;
}

.cb-status,
.cb-qualification,
.cb-date-expired {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	border-radius: 999px;
	padding: 9px 13px;
	font-size: 12px;
	font-weight: 900;
	line-height: 1.2;
	text-align: right;
}

.cb-status--pending {
	background: #fff7ed;
	color: #9a4a00;
	border: 1px solid #ffd4b4;
}

.cb-status--confirmed {
	background: #e8fff6;
	color: #087f5b;
	border: 1px solid #b8f3dc;
}

.cb-status--cancelled {
	background: #fff0f0;
	color: #b42318;
	border: 1px solid #ffd0d0;
}

.cb-qualification--reserve {
	background: #fff7ed;
	color: #9a4a00;
	border: 1px solid #ffd4b4;
}

.cb-qualification--qualified {
	background: #e8fff6;
	color: #087f5b;
	border: 1px solid #b8f3dc;
}

.cb-date-expired {
	background: #f1f5f9;
	color: #64748b;
	border: 1px solid #e2e8f0;
}

.cb-confirm-form {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	gap: 8px;
	margin: 0;
}

.cb-action-btn {
	border: 0;
	border-radius: 14px;
	min-height: 38px;
	padding: 0 14px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	font-size: 12px;
	font-weight: 900;
	cursor: pointer;
	transition: .2s ease;
}

.cb-action-btn i {
	font-size: 17px;
}

.cb-action-btn--success {
	background: linear-gradient(135deg, #0ca678 0%, #20c997 100%);
	color: #ffffff;
	box-shadow: 0 10px 22px rgba(12, 166, 120, .22);
}

.cb-action-btn--success:hover {
	transform: translateY(-1px);
	box-shadow: 0 14px 28px rgba(12, 166, 120, .28);
}

.cb-action-btn--danger {
	background: linear-gradient(135deg, #e03131 0%, #ff6b6b 100%);
	color: #ffffff;
	box-shadow: 0 10px 22px rgba(224, 49, 49, .18);
}

.cb-action-btn--danger:hover {
	transform: translateY(-1px);
	box-shadow: 0 14px 28px rgba(224, 49, 49, .25);
}

@media (max-width: 900px) {
	.cb-inscription-card {
		grid-template-columns: 1fr;
	}

	.cb-inscription-side {
		align-items: flex-start;
		min-width: 0;
		width: 100%;
	}

	.cb-confirm-form {
		width: 100%;
		justify-content: flex-start;
		flex-wrap: wrap;
	}
}

@media (max-width: 600px) {
	.cb-inscription-card {
		padding: 16px;
		border-radius: 18px;
	}

	.cb-inscription-main {
		flex-direction: column;
		gap: 12px;
	}

	.cb-inscription-icon {
		width: 50px;
		height: 50px;
		border-radius: 16px;
		font-size: 24px;
	}

	.cb-inscription-content h4 {
		font-size: 17px;
	}

	.cb-status,
	.cb-qualification,
	.cb-date-expired {
		border-radius: 14px;
		width: 100%;
		justify-content: flex-start;
		text-align: left;
	}

	.cb-action-btn {
		width: 100%;
	}
}
/* =========================================================
   Championnats de Belgique - Doubles
   ========================================================= */

.cb-double-players {
	margin-top: 14px;
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}

.cb-double-player {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 999px;
	padding: 9px 13px;
	color: #071b33;
	font-size: 13px;
	font-weight: 900;
}

.cb-double-player i {
	color: #ee5a24;
	font-size: 17px;
}

.cb-double-separator {
	width: 34px;
	height: 34px;
	border-radius: 999px;
	background: #fff4ec;
	color: #ee5a24;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 900;
}

.cb-double-separator i {
	font-size: 17px;
}

@media (max-width: 600px) {
	.cb-double-players {
		flex-direction: column;
		align-items: flex-start;
	}

	.cb-double-player {
		width: 100%;
		border-radius: 14px;
	}

	.cb-double-separator {
		width: 100%;
		height: 30px;
		border-radius: 14px;
	}
}
/* =========================================================
   Nouveau classement
   ========================================================= */

.ranking-modern-page {
	max-width: 1180px;
	margin: 0 auto;
}

.ranking-section {
	margin-bottom: 20px;
}

.ranking-cards-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

.ranking-card {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 22px;
	padding: 22px;
	min-height: 230px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	box-shadow: 0 10px 28px rgba(15, 34, 54, .05);
	transition: .2s ease;
}

.ranking-card:hover {
	transform: translateY(-1px);
	box-shadow: 0 16px 36px rgba(15, 34, 54, .08);
	border-color: rgba(238, 90, 36, .25);
}

.ranking-card__label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: #6f7d95;
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
}

.ranking-card__label i {
	color: #ee5a24;
	font-size: 18px;
}

.ranking-card__value {
	margin: 18px 0 10px 0;
	color: #071b33;
	font-size: 64px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: -0.05em;
}

.ranking-card p {
	margin: 0;
	color: #6f7d95;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.5;
}

.ranking-card--current {
	background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
}

.ranking-card--proposal {
	background: linear-gradient(135deg, #fff4ec 0%, #ffffff 100%);
	border-color: #ffd4b4;
}

.ranking-card--proposal .ranking-card__value {
	color: #ee5a24;
}

.ranking-card--women {
	background: linear-gradient(135deg, #f0fff8 0%, #ffffff 100%);
	border-color: #b8f3dc;
}

.ranking-card--women .ranking-card__value {
	color: #087f5b;
}

.ranking-card--claim {
	background: #071b33;
	color: #ffffff;
}

.ranking-card--claim .ranking-card__label,
.ranking-card--claim .ranking-card__label i {
	color: #ffffff;
}

.ranking-card__claim-content {
	display: flex;
	flex-direction: column;
	gap: 16px;
	margin-top: 20px;
}

.ranking-claim-btn {
	border: 0;
	border-radius: 16px;
	background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%);
	color: #ffffff;
	font-size: 13px;
	font-weight: 900;
	padding: 13px 18px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	cursor: pointer;
	box-shadow: 0 12px 26px rgba(238, 90, 36, .28);
	transition: .2s ease;
	width: 100%;
}

.ranking-claim-btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 16px 32px rgba(238, 90, 36, .34);
}

.ranking-claim-message {
	color: rgba(255, 255, 255, .82);
	font-size: 13px;
	font-weight: 700;
	line-height: 1.55;
}

.ranking-reclamation-box {
	margin-top: 18px;
	border: 1px solid #edf1f7;
	border-radius: 22px;
	background: #ffffff;
	overflow: hidden;
	box-shadow: 0 10px 28px rgba(15, 34, 54, .05);
}

.ranking-reclamation-box__header {
	padding: 20px 22px;
	background: #f8fafc;
	border-bottom: 1px solid #edf1f7;
	display: flex;
	align-items: center;
	gap: 14px;
}

.ranking-reclamation-box__header i {
	width: 46px;
	height: 46px;
	border-radius: 16px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
}

.ranking-reclamation-box__header h4 {
	margin: 0;
	color: #071b33;
	font-size: 17px;
	font-weight: 900;
}

.ranking-reclamation-box__header span {
	display: block;
	margin-top: 3px;
	color: #6f7d95;
	font-size: 12px;
	font-weight: 700;
}

.ranking-reclamation-box__body {
	padding: 22px;
}

.ranking-reclamation-box__body strong {
	display: block;
	color: #071b33;
	font-size: 13px;
	font-weight: 900;
	margin-bottom: 8px;
}

.ranking-reclamation-box__body p {
	color: #6f7d95;
	font-weight: 700;
	line-height: 1.6;
	margin: 0 0 18px 0;
}

.ranking-reclamation-result {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 14px;
}

.ranking-reclamation-result span {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 16px;
}

.ranking-reclamation-result em {
	display: block;
	color: #ee5a24;
	font-size: 28px;
	font-weight: 900;
	font-style: normal;
	line-height: 1;
}

@media (max-width: 991px) {
	.ranking-cards-grid {
		grid-template-columns: 1fr;
	}

	.ranking-card {
		min-height: auto;
	}

	.ranking-card__value {
		font-size: 52px;
	}
}

@media (max-width: 600px) {
	.ranking-card {
		border-radius: 18px;
		padding: 18px;
	}

	.ranking-card__value {
		font-size: 46px;
	}

	.ranking-reclamation-result {
		grid-template-columns: 1fr;
	}
}
/* =========================================================
   Archives classement / résultats
   ========================================================= */

.archives-modern-page {
	max-width: 1180px;
	margin: 0 auto;
}

.archives-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

.archive-season-card {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 22px;
	padding: 20px;
	box-shadow: 0 10px 28px rgba(15, 34, 54, .05);
	transition: .2s ease;
	position: relative;
	overflow: hidden;
}

.archive-season-card::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 5px;
	background: #cbd5e1;
}

.archive-season-card--up::before {
	background: linear-gradient(180deg, #0ca678 0%, #20c997 100%);
}

.archive-season-card--down::before {
	background: linear-gradient(180deg, #e03131 0%, #ff6b6b 100%);
}

.archive-season-card--stable::before {
	background: linear-gradient(180deg, #ee5a24 0%, #ff8a00 100%);
}

.archive-season-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 16px 36px rgba(15, 34, 54, .08);
	border-color: rgba(238, 90, 36, .22);
}

.archive-season-card__top {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 18px;
}

.archive-season-label {
	display: block;
	color: #6f7d95;
	font-size: 11px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .05em;
	margin-bottom: 5px;
}

.archive-season-card h4 {
	margin: 0;
	color: #071b33;
	font-size: 18px;
	font-weight: 900;
	line-height: 1.2;
}

.archive-movement {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	border-radius: 999px;
	padding: 7px 10px;
	font-size: 11px;
	font-weight: 900;
	white-space: nowrap;
}

.archive-movement--up {
	background: #e8fff6;
	color: #087f5b;
	border: 1px solid #b8f3dc;
}

.archive-movement--down {
	background: #fff0f0;
	color: #b42318;
	border: 1px solid #ffd0d0;
}

.archive-movement--stable {
	background: #fff4ec;
	color: #ee5a24;
	border: 1px solid #ffd4b4;
}

.archive-ranking-flow {
	display: grid;
	grid-template-columns: 1fr 36px 1fr;
	gap: 10px;
	align-items: center;
	margin-bottom: 18px;
}

.archive-ranking-box {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 16px 12px;
	text-align: center;
}

.archive-ranking-box span {
	display: block;
	color: #6f7d95;
	font-size: 10px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 7px;
}

.archive-ranking-box strong {
	display: block;
	color: #071b33;
	font-size: 30px;
	font-weight: 900;
	line-height: 1;
}

.archive-ranking-box--next {
	background: #fff4ec;
	border-color: #ffd4b4;
}

.archive-ranking-box--next strong {
	color: #ee5a24;
}

.archive-ranking-arrow {
	width: 36px;
	height: 36px;
	border-radius: 999px;
	background: #071b33;
	color: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
}

.archive-ranking-arrow i {
	font-size: 18px;
}

.archive-stats-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 8px;
}

.archive-stats-grid div {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 15px;
	padding: 12px 8px;
	text-align: center;
}

.archive-stats-grid strong {
	display: block;
	color: #071b33;
	font-size: 20px;
	font-weight: 900;
	line-height: 1;
}

.archive-stats-grid span {
	display: block;
	margin-top: 6px;
	color: #6f7d95;
	font-size: 10px;
	font-weight: 800;
	text-transform: uppercase;
	line-height: 1.2;
}

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

@media (max-width: 700px) {
	.archives-grid {
		grid-template-columns: 1fr;
	}

	.archive-ranking-flow {
		grid-template-columns: 1fr;
	}

	.archive-ranking-arrow {
		margin: 0 auto;
		transform: rotate(90deg);
	}

	.archive-stats-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
/* Variante dames pour archives */

.archive-ranking-box--women {
	background: #f0fff8 !important;
	border-color: #b8f3dc !important;
}

.archive-ranking-box--women strong {
	color: #087f5b !important;
}
/* =========================================================
   Réclamation de classement mi-saison
   ========================================================= */

.midseason-claim-page {
	max-width: 1100px;
	margin: 0 auto;
}

.midseason-info-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
	margin-bottom: 22px;
}

.midseason-info-card {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 18px;
	display: flex;
	gap: 12px;
	align-items: flex-start;
	min-height: 145px;
}

.midseason-info-card__icon {
	width: 42px;
	height: 42px;
	min-width: 42px;
	border-radius: 14px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 21px;
}

.midseason-info-card strong {
	display: block;
	color: #071b33;
	font-size: 14px;
	font-weight: 900;
	margin-bottom: 6px;
}

.midseason-info-card span {
	display: block;
	color: #6f7d95;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.45;
}

.midseason-ranking-box {
	background: linear-gradient(135deg, #071b33 0%, #0d2f4f 100%);
	border-radius: 22px;
	padding: 24px;
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 24px;
	align-items: center;
	margin-bottom: 18px;
	box-shadow: 0 16px 36px rgba(7, 27, 51, .18);
}

.midseason-ranking-box__left {
	border-right: 1px solid rgba(255,255,255,.14);
	padding-right: 24px;
}

.midseason-ranking-box__left span {
	display: block;
	color: rgba(255,255,255,.72);
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 8px;
}

.midseason-ranking-box__left strong {
	display: block;
	color: #ffffff;
	font-size: 68px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: -0.05em;
}

.midseason-ranking-box__right {
	display: flex;
	align-items: center;
	justify-content: flex-end;
}

.midseason-claim-btn {
	border: 0;
	border-radius: 16px;
	background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%);
	color: #ffffff;
	font-size: 14px;
	font-weight: 900;
	padding: 15px 22px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 9px;
	cursor: pointer;
	box-shadow: 0 14px 30px rgba(238, 90, 36, .32);
	transition: .2s ease;
}

.midseason-claim-btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 18px 36px rgba(238, 90, 36, .38);
}

.midseason-claim-btn i {
	font-size: 18px;
}

.midseason-claim-sent {
	background: rgba(255,255,255,.09);
	border: 1px solid rgba(255,255,255,.14);
	border-radius: 18px;
	padding: 18px;
	display: flex;
	align-items: center;
	gap: 14px;
	color: #ffffff;
	width: 100%;
}

.midseason-claim-sent i {
	width: 46px;
	height: 46px;
	border-radius: 16px;
	background: #e8fff6;
	color: #087f5b;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 23px;
}

.midseason-claim-sent strong {
	display: block;
	font-size: 16px;
	font-weight: 900;
	margin-bottom: 4px;
}

.midseason-claim-sent span {
	display: block;
	color: rgba(255,255,255,.76);
	font-size: 13px;
	font-weight: 700;
	line-height: 1.45;
}

@media (max-width: 1100px) {
	.midseason-info-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 700px) {
	.midseason-info-grid {
		grid-template-columns: 1fr;
	}

	.midseason-ranking-box {
		grid-template-columns: 1fr;
		gap: 18px;
		padding: 20px;
	}

	.midseason-ranking-box__left {
		border-right: 0;
		border-bottom: 1px solid rgba(255,255,255,.14);
		padding-right: 0;
		padding-bottom: 18px;
		text-align: center;
	}

	.midseason-ranking-box__left strong {
		font-size: 56px;
	}

	.midseason-ranking-box__right {
		justify-content: stretch;
	}

	.midseason-ranking-box__right form,
	.midseason-claim-btn {
		width: 100%;
	}

	.midseason-claim-sent {
		align-items: flex-start;
	}
}
.midseason-claim-sent--closed i {
	background: #fff7ed !important;
	color: #9a4a00 !important;
}
.midseason-ranking-box--women .midseason-claim-btn {
	background: linear-gradient(135deg, #0ca678 0%, #20c997 100%);
	box-shadow: 0 14px 30px rgba(12, 166, 120, .28);
}

.midseason-ranking-box--women .midseason-claim-btn:hover {
	box-shadow: 0 18px 36px rgba(12, 166, 120, .34);
}

.midseason-ranking-box--women .midseason-ranking-box__left strong {
	color: #20c997;
}

.midseason-claim-sent--closed i {
	background: #fff7ed !important;
	color: #9a4a00 !important;
}
/* =========================================================
   Agenda compétitions
   ========================================================= */

.agenda-modern-page {
	max-width: 1180px;
	margin: 0 auto;
}

.agenda-list {
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.agenda-competition-card {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 24px;
	padding: 20px;
	display: grid;
	grid-template-columns: 112px 1fr;
	gap: 20px;
	box-shadow: 0 10px 28px rgba(15, 34, 54, .05);
	transition: .2s ease;
}

.agenda-competition-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 16px 36px rgba(15, 34, 54, .08);
	border-color: rgba(238, 90, 36, .25);
}

.agenda-date-box {
	background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%);
	color: #ffffff;
	border-radius: 22px;
	min-height: 112px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	box-shadow: 0 14px 30px rgba(238, 90, 36, .22);
}

.agenda-date-box strong {
	font-size: 42px;
	font-weight: 900;
	line-height: 1;
}

.agenda-date-box span {
	margin-top: 6px;
	font-size: 14px;
	font-weight: 900;
	text-transform: uppercase;
}

.agenda-date-box em {
	margin-top: 2px;
	font-size: 12px;
	font-style: normal;
	font-weight: 700;
	opacity: .85;
}

.agenda-competition-content {
	min-width: 0;
}

.agenda-competition-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 16px;
	margin-bottom: 16px;
}

.agenda-level-badge {
	display: inline-flex;
	align-items: center;
	border-radius: 999px;
	padding: 6px 10px;
	background: #fff4ec;
	color: #ee5a24;
	font-size: 11px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 8px;
}

.agenda-competition-header h4 {
	margin: 0;
	color: #071b33;
	font-size: 21px;
	font-weight: 900;
	line-height: 1.25;
}

.agenda-register-btn {
	border: 0;
	border-radius: 15px;
	background: #071b33;
	color: #ffffff !important;
	font-size: 13px;
	font-weight: 900;
	padding: 12px 16px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	white-space: nowrap;
	box-shadow: 0 12px 26px rgba(7, 27, 51, .16);
	transition: .2s ease;
}

.agenda-register-btn:hover {
	transform: translateY(-1px);
	background: #0d2f4f;
	color: #ffffff !important;
	text-decoration: none;
}

.agenda-meta-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
	margin-bottom: 16px;
}

.agenda-meta-item {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 14px;
	display: flex;
	gap: 12px;
	align-items: flex-start;
}

.agenda-meta-item i {
	width: 38px;
	height: 38px;
	min-width: 38px;
	border-radius: 13px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 19px;
}

.agenda-meta-item strong {
	display: block;
	color: #071b33;
	font-size: 12px;
	font-weight: 900;
	margin-bottom: 4px;
	text-transform: uppercase;
	letter-spacing: .03em;
}

.agenda-meta-item span {
	display: block;
	color: #6f7d95;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.45;
}

.agenda-series-block {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 15px;
}

.agenda-series-block > strong {
	display: block;
	color: #071b33;
	font-size: 13px;
	font-weight: 900;
	margin-bottom: 10px;
}

.agenda-series-list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.agenda-series-list span {
	display: inline-flex;
	align-items: center;
	border-radius: 999px;
	background: #eef4ff;
	color: #2457c5;
	padding: 7px 11px;
	font-size: 12px;
	font-weight: 900;
}

@media (max-width: 900px) {
	.agenda-competition-card {
		grid-template-columns: 1fr;
	}

	.agenda-date-box {
		min-height: auto;
		padding: 18px;
		flex-direction: row;
		gap: 8px;
		justify-content: flex-start;
	}

	.agenda-date-box strong {
		font-size: 34px;
	}

	.agenda-date-box span,
	.agenda-date-box em {
		margin-top: 0;
	}
}

@media (max-width: 700px) {
	.agenda-competition-header {
		flex-direction: column;
	}

	.agenda-register-btn {
		width: 100%;
		justify-content: center;
	}

	.agenda-meta-grid {
		grid-template-columns: 1fr;
	}
}
/* =========================================================
   Éthique / certificats encadrants
   ========================================================= */

.ethics-modern-page {
	max-width: 1180px;
	margin: 0 auto;
}

.ethics-info-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
	margin-bottom: 24px;
}

.ethics-info-card {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 18px;
	display: flex;
	gap: 12px;
	align-items: flex-start;
	min-height: 150px;
}

.ethics-info-card i {
	width: 42px;
	height: 42px;
	min-width: 42px;
	border-radius: 14px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 21px;
}

.ethics-info-card strong {
	display: block;
	color: #071b33;
	font-size: 14px;
	font-weight: 900;
	margin-bottom: 6px;
}

.ethics-info-card span {
	display: block;
	color: #6f7d95;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.45;
}

.ethics-form {
	margin-top: 8px;
}

.ethics-file-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: #ee5a24;
	font-weight: 900;
}

.ethics-file-link:hover {
	color: #d9480f;
	text-decoration: none;
}

.ethics-status {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	border-radius: 999px;
	padding: 7px 11px;
	font-size: 11px;
	font-weight: 900;
	white-space: nowrap;
}

.ethics-status--valid {
	background: #e8fff6;
	color: #087f5b;
	border: 1px solid #b8f3dc;
}

.ethics-status--invalid {
	background: #fff0f0;
	color: #b42318;
	border: 1px solid #ffd0d0;
}

.ethics-status--pending {
	background: #fff7ed;
	color: #9a4a00;
	border: 1px solid #ffd4b4;
}

.ethics-table td,
.ethics-table th {
	vertical-align: middle !important;
}

@media (max-width: 1100px) {
	.ethics-info-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 700px) {
	.ethics-info-grid {
		grid-template-columns: 1fr;
	}

	.ethics-info-card {
		min-height: auto;
	}
}
/* =========================================================
   Transfert
   ========================================================= */

.transfer-modern-page {
	max-width: 1180px;
	margin: 0 auto;
}

.transfer-timeline {
	display: grid;
	grid-template-columns: 1fr 80px 1fr;
	align-items: center;
	gap: 16px;
	margin-bottom: 18px;
}

.transfer-timeline-item {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 22px;
	padding: 18px;
	display: flex;
	gap: 14px;
	align-items: center;
	box-shadow: 0 10px 28px rgba(15, 34, 54, .05);
}

.transfer-timeline-icon {
	width: 48px;
	height: 48px;
	min-width: 48px;
	border-radius: 16px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 23px;
}

.transfer-timeline-item strong {
	display: block;
	color: #071b33;
	font-size: 15px;
	font-weight: 900;
	margin-bottom: 4px;
}

.transfer-timeline-item span {
	display: block;
	color: #6f7d95;
	font-size: 13px;
	font-weight: 700;
}

.transfer-timeline-separator {
	height: 3px;
	background: linear-gradient(90deg, #ee5a24 0%, #ff8a00 100%);
	border-radius: 999px;
}

.transfer-info-box {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 18px;
}

.transfer-info-box p {
	color: #41516a;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.65;
	margin: 0 0 12px 0;
}

.transfer-info-box p:last-child {
	margin-bottom: 0;
}

.transfer-info-box strong {
	color: #071b33;
	font-weight: 900;
}

.transfer-actions-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px;
	margin-bottom: 18px;
}

.transfer-form-intro {
	margin-bottom: 14px;
}

.transfer-form-intro strong {
	display: block;
	color: #071b33;
	font-size: 14px;
	font-weight: 900;
	margin-bottom: 4px;
}

.transfer-form-intro span {
	display: block;
	color: #6f7d95;
	font-size: 13px;
	font-weight: 700;
}

.transfer-checkbox-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
	margin-bottom: 16px;
}

.transfer-choice-card {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 16px;
	display: flex;
	gap: 12px;
	align-items: flex-start;
	cursor: pointer;
	transition: .2s ease;
}

.transfer-choice-card:hover {
	border-color: rgba(238, 90, 36, .35);
	box-shadow: 0 10px 24px rgba(238, 90, 36, .08);
}

.transfer-choice-card input {
	margin-top: 4px;
	accent-color: #ee5a24;
}

.transfer-choice-card strong {
	display: block;
	color: #071b33;
	font-size: 14px;
	font-weight: 900;
	margin-bottom: 4px;
}

.transfer-choice-card small {
	display: block;
	color: #6f7d95;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.35;
}

.transfer-status {
	border-radius: 18px;
	padding: 16px;
	display: flex;
	gap: 13px;
	align-items: flex-start;
	font-weight: 700;
}

.transfer-status i {
	width: 42px;
	height: 42px;
	min-width: 42px;
	border-radius: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
}

.transfer-status strong {
	display: block;
	font-size: 15px;
	font-weight: 900;
	margin-bottom: 4px;
}

.transfer-status span {
	display: block;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.45;
}

.transfer-status--success {
	background: #e8fff6;
	color: #087f5b;
	border: 1px solid #b8f3dc;
}

.transfer-status--success i {
	background: #ffffff;
	color: #087f5b;
}

.transfer-status--warning {
	background: #fff7ed;
	color: #9a4a00;
	border: 1px solid #ffd4b4;
}

.transfer-status--warning i {
	background: #ffffff;
	color: #9a4a00;
}

.transfer-status--danger {
	background: #fff0f0;
	color: #b42318;
	border: 1px solid #ffd0d0;
}

.transfer-status--danger i {
	background: #ffffff;
	color: #b42318;
}

.transfer-status--closed {
	background: #f8fafc;
	color: #64748b;
	border: 1px solid #e2e8f0;
}

.transfer-status--closed i {
	background: #ffffff;
	color: #64748b;
}

.transfer-info-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-bottom: 16px;
}

.transfer-info-list div {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 16px;
	padding: 13px;
	display: flex;
	gap: 10px;
	align-items: flex-start;
	color: #41516a;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.45;
}

.transfer-info-list i {
	color: #ee5a24;
	font-size: 18px;
	margin-top: 1px;
}

.transfer-selected-club {
	background: #071b33;
	color: #ffffff;
	border-radius: 18px;
	padding: 18px;
	margin-bottom: 14px;
}

.transfer-selected-club span {
	display: block;
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	opacity: .75;
	margin-bottom: 6px;
}

.transfer-selected-club strong {
	display: block;
	font-size: 20px;
	font-weight: 900;
	line-height: 1.25;
}

.transfer-doc-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}

.transfer-doc-card {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 20px;
	padding: 18px;
	display: grid;
	grid-template-columns: 54px 1fr;
	gap: 14px;
}

.transfer-doc-card__icon {
	width: 54px;
	height: 54px;
	border-radius: 17px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 26px;
}

.transfer-doc-card h4 {
	margin: 0;
	color: #071b33;
	font-size: 18px;
	font-weight: 900;
}

.transfer-doc-card p {
	margin: 6px 0 14px 0;
	color: #6f7d95;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.45;
}

.transfer-doc-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 10px;
}

.transfer-link-btn {
	border-radius: 13px;
	background: #071b33;
	color: #ffffff !important;
	padding: 10px 12px;
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-size: 12px;
	font-weight: 900;
	text-decoration: none !important;
	transition: .2s ease;
}

.transfer-link-btn:hover {
	background: #0d2f4f;
	transform: translateY(-1px);
}

.transfer-doc-muted {
	display: block;
	color: #6f7d95;
	font-size: 12px;
	font-weight: 700;
}

@media (max-width: 991px) {
	.transfer-timeline {
		grid-template-columns: 1fr;
	}

	.transfer-timeline-separator {
		height: 34px;
		width: 3px;
		margin: 0 auto;
	}

	.transfer-actions-grid,
	.transfer-doc-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 600px) {
	.transfer-checkbox-grid {
		grid-template-columns: 1fr;
	}

	.transfer-doc-card {
		grid-template-columns: 1fr;
	}

	.transfer-doc-card__icon {
		width: 48px;
		height: 48px;
	}

	.transfer-selected-club strong {
		font-size: 17px;
	}
}


.transfer-actions-grid .affiliation-card {
	overflow: hidden;
}
/* Correction padding interne des cartes transfert */
.transfer-actions-grid .affiliation-card__body {
	padding: 26px !important;
}

.transfer-actions-grid .transfer-status {
	margin: 0 !important;
	width: 100%;
	box-sizing: border-box;
}

/* Sécurité : évite que le bloc touche le bord de la carte */
.transfer-actions-grid .affiliation-card__body > .transfer-status:first-child {
	margin-top: 0 !important;
}
/* =========================================================
   Listing confirmations transferts
   ========================================================= */

.transfer-listing-page {
	max-width: 1280px;
	margin: 0 auto;
}

.transfer-listing-table-wrapper {
	border-radius: 18px;
}

.transfer-listing-table tfoot th {
	background: #ffffff;
	border-top: 1px solid #edf0f5;
	padding: 12px 14px;
}

.transfer-listing-table tfoot input {
	width: 100%;
	border: 1px solid #dfe3ec;
	border-radius: 10px;
	min-height: 38px;
	padding: 8px 10px;
	font-size: 12px;
	font-weight: 700;
	color: #2f3044;
}

.transfer-listing-table tfoot input:focus {
	border-color: #ee5a24;
	box-shadow: 0 0 0 3px rgba(238, 90, 36, .10);
	outline: none;
}

.transfer-ranking-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 48px;
	border-radius: 999px;
	background: #fff4ec;
	color: #ee5a24;
	border: 1px solid #ffd4bd;
	padding: 7px 10px;
	font-size: 12px;
	font-weight: 900;
}

.transfer-ranking-badge--women {
	background: #f0fff8;
	color: #087f5b;
	border-color: #b8f3dc;
}

.transfer-listing-status {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	min-width: 220px;
	padding: 12px;
	border-radius: 14px;
	border: 1px solid #edf0f5;
	background: #f8fafc;
}

.transfer-listing-status i {
	width: 34px;
	height: 34px;
	min-width: 34px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	background: #ffffff;
}

.transfer-listing-status strong {
	display: block;
	font-size: 13px;
	font-weight: 900;
	margin-bottom: 3px;
}

.transfer-listing-status span {
	display: block;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.35;
}

.transfer-listing-status--confirmed {
	background: #e8fff6;
	color: #087f5b;
	border-color: #b8f3dc;
}

.transfer-listing-status--confirmed i {
	color: #087f5b;
}

.transfer-listing-status--pending {
	background: #fff7ed;
	color: #9a4a00;
	border-color: #ffd4b4;
}

.transfer-listing-status--pending i {
	color: #9a4a00;
}

/* DataTables dans le style moderne */
.transfer-listing-page .dataTables_wrapper .dataTables_filter input,
.transfer-listing-page .dataTables_wrapper .dataTables_length select {
	border: 1px solid #dfe3ec;
	border-radius: 10px;
	min-height: 36px;
	padding: 6px 10px;
	margin-left: 8px;
}

.transfer-listing-page .dataTables_wrapper .dataTables_filter input:focus {
	border-color: #ee5a24;
	box-shadow: 0 0 0 3px rgba(238, 90, 36, .10);
	outline: none;
}

.transfer-listing-page .dataTables_wrapper .dataTables_paginate .paginate_button.current {
	background: #ee5a24 !important;
	color: #ffffff !important;
	border: 1px solid #ee5a24 !important;
	border-radius: 8px;
}

.transfer-listing-page .dataTables_wrapper .dataTables_paginate .paginate_button:hover {
	background: #fff4ec !important;
	color: #ee5a24 !important;
	border: 1px solid #ffd4bd !important;
	border-radius: 8px;
}

@media (max-width: 700px) {
	.transfer-listing-status {
		min-width: 180px;
	}

	.transfer-listing-table-wrapper {
		overflow-x: auto;
	}
}
/* =========================================================
   Listing inscriptions transferts
   ========================================================= */

.transfer-ranking-badge--index {
	background: #eef4ff;
	color: #2457c5;
	border-color: #cfe0ff;
}

.transfer-contact-list {
	display: flex;
	flex-direction: column;
	gap: 6px;
	min-width: 190px;
}

.transfer-contact-list span {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: #41516a;
	font-size: 12px;
	font-weight: 800;
	line-height: 1.35;
}

.transfer-contact-list i {
	color: #ee5a24;
	font-size: 15px;
}

.transfer-remark {
	display: inline-flex;
	align-items: center;
	max-width: 280px;
	color: #41516a;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.4;
}
/* =========================================================
   Fiche personnelle
   ========================================================= */

.profile-modern-page {
	max-width: 1280px;
	margin: 0 auto;
}

.profile-summary-card {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 24px;
	padding: 22px;
	display: flex;
	justify-content: space-between;
	gap: 22px;
	align-items: center;
	margin-bottom: 18px;
	box-shadow: 0 12px 35px rgba(15, 34, 54, .06);
}

.profile-summary-main {
	display: flex;
	align-items: center;
	gap: 18px;
	min-width: 0;
}

.profile-photo-large {
	width: 82px;
	height: 82px;
	border-radius: 24px;
	background: #fff4ec;
	overflow: hidden;
	border: 4px solid #ffffff;
	box-shadow: 0 8px 22px rgba(15, 34, 54, .12);
	flex: 0 0 auto;
}

.profile-photo-large img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.profile-label {
	display: inline-flex;
	align-items: center;
	border-radius: 999px;
	background: #fff4ec;
	color: #ee5a24;
	font-size: 11px;
	font-weight: 900;
	padding: 5px 10px;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 8px;
}

.profile-summary-main h3 {
	margin: 0;
	color: #071b33;
	font-size: 24px;
	font-weight: 900;
	line-height: 1.15;
}

.profile-summary-main p {
	margin: 6px 0 0 0;
	color: #6f7d95;
	font-size: 13px;
	font-weight: 700;
}

.profile-summary-badges {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 8px;
}

.profile-summary-badges span {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 999px;
	padding: 9px 12px;
	color: #071b33;
	font-size: 12px;
	font-weight: 900;
}

.profile-summary-badges i {
	color: #ee5a24;
	font-size: 16px;
}

.profile-grid {
	display: grid;
	grid-template-columns: 330px 1fr;
	gap: 18px;
	align-items: start;
}

.profile-side-column,
.profile-main-column {
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.profile-nav-list {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.profile-nav-list a {
	display: flex;
	align-items: center;
	gap: 10px;
	border-radius: 15px;
	padding: 13px 14px;
	background: #f8fafc;
	color: #071b33;
	font-size: 13px;
	font-weight: 900;
	text-decoration: none !important;
	transition: .2s ease;
}

.profile-nav-list a i {
	width: 34px;
	height: 34px;
	border-radius: 12px;
	background: #ffffff;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 17px;
}

.profile-nav-list a:hover,
.profile-nav-list a.active {
	background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%);
	color: #ffffff;
	box-shadow: 0 12px 28px rgba(238, 90, 36, .22);
}

.profile-nav-list a:hover i,
.profile-nav-list a.active i {
	color: #ee5a24;
	background: #ffffff;
}

.profile-action-card {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 22px;
	padding: 18px;
	display: grid;
	grid-template-columns: 54px 1fr;
	gap: 14px;
	box-shadow: 0 10px 28px rgba(15, 34, 54, .05);
}

.profile-action-card__icon {
	width: 54px;
	height: 54px;
	border-radius: 17px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 25px;
}

.profile-action-card span {
	display: inline-flex;
	align-items: center;
	border-radius: 999px;
	background: #f8fafc;
	color: #6f7d95;
	font-size: 10px;
	font-weight: 900;
	padding: 4px 9px;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 7px;
}

.profile-action-card h4 {
	margin: 0;
	color: #071b33;
	font-size: 17px;
	font-weight: 900;
}

.profile-action-card p {
	margin: 7px 0 13px 0;
	color: #6f7d95;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.45;
}

.profile-small-btn {
	border: 0;
	border-radius: 13px;
	background: #071b33;
	color: #ffffff !important;
	padding: 10px 12px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	font-size: 12px;
	font-weight: 900;
	text-decoration: none !important;
	cursor: pointer;
	transition: .2s ease;
}

.profile-small-btn:hover {
	background: #0d2f4f;
	transform: translateY(-1px);
}

.profile-small-btn--button {
	font-family: inherit;
}

.profile-photo-form {
	margin: 0;
}

.profile-photo-edit {
	display: grid;
	grid-template-columns: 120px 1fr;
	gap: 18px;
	align-items: center;
}

.profile-photo-preview {
	width: 120px;
	height: 120px;
	border-radius: 28px;
	overflow: hidden;
	background: #fff4ec;
	border: 4px solid #ffffff;
	box-shadow: 0 8px 22px rgba(15, 34, 54, .12);
}

.profile-photo-preview img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.profile-photo-input label {
	display: block;
	color: #071b33;
	font-size: 13px;
	font-weight: 900;
	margin-bottom: 8px;
}

.profile-photo-input small {
	display: block;
	margin-top: 7px;
	color: #6f7d95;
	font-size: 12px;
	font-weight: 700;
}

.profile-form-section {
	padding: 20px 0;
	border-bottom: 1px solid #edf1f7;
}

.profile-form-section:first-child {
	padding-top: 0;
}

.profile-form-section:last-of-type {
	border-bottom: 0;
}

.profile-form-section__title {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 16px;
	color: #071b33;
	font-size: 15px;
	font-weight: 900;
}

.profile-form-section__title i {
	width: 38px;
	height: 38px;
	border-radius: 13px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 19px;
}

.profile-form-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
}

.profile-field-wide {
	grid-column: 1 / -1;
}

.profile-radio-row {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
}

.profile-radio-card {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 16px;
	display: flex;
	align-items: flex-start;
	gap: 12px;
	cursor: pointer;
	transition: .2s ease;
}

.profile-radio-card:hover {
	border-color: rgba(238, 90, 36, .35);
	box-shadow: 0 10px 24px rgba(238, 90, 36, .08);
}

.profile-radio-card input {
	margin-top: 4px;
	accent-color: #ee5a24;
}

.profile-radio-card strong {
	display: block;
	color: #071b33;
	font-size: 14px;
	font-weight: 900;
	margin-bottom: 4px;
}

.profile-radio-card small {
	display: block;
	color: #6f7d95;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.4;
}

.profile-modern-page .input-group-text {
	background: #fff4ec;
	border-color: #ffd4bd;
	color: #ee5a24;
}

@media (max-width: 1100px) {
	.profile-grid {
		grid-template-columns: 1fr;
	}

	.profile-side-column {
		order: 2;
	}

	.profile-main-column {
		order: 1;
	}
}

@media (max-width: 700px) {
	.profile-summary-card {
		flex-direction: column;
		align-items: flex-start;
	}

	.profile-summary-badges {
		justify-content: flex-start;
	}

	.profile-photo-edit {
		grid-template-columns: 1fr;
	}

	.profile-photo-preview {
		width: 100px;
		height: 100px;
	}

	.profile-form-grid,
	.profile-radio-row {
		grid-template-columns: 1fr;
	}

	.profile-action-card {
		grid-template-columns: 1fr;
	}

	.profile-action-card__icon {
		width: 48px;
		height: 48px;
	}
}
.affiliation-rgpd-box {
	display: flex;
	gap: 18px;
	padding: 22px 24px;
	border: 1px solid #ffd7c2;
	background: #fff7f2;
	border-radius: 20px;
	margin-top: 24px;
}

.affiliation-rgpd-box__icon {
	width: 56px;
	height: 56px;
	border-radius: 18px;
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	border: 1px solid #ffe3d2;
}

.affiliation-rgpd-box__icon i {
	font-size: 24px;
	color: #ff6b1a;
}

.affiliation-rgpd-box__content h4 {
	margin: 0 0 8px 0;
	font-size: 18px;
	font-weight: 700;
	color: #1f2a44;
}

.affiliation-rgpd-box__content p {
	margin-bottom: 10px;
	color: #5f6b85;
	line-height: 1.6;
}

.affiliation-rgpd-box__content ul {
	margin: 0 0 12px 18px;
	padding: 0;
	color: #1f2a44;
}

.affiliation-rgpd-box__content li {
	margin-bottom: 6px;
	line-height: 1.5;
}
/* =========================================================
   Fiche personnelle - corrections cartes latérales
   ========================================================= */

.profile-action-card__icon i,
.profile-rgpd-card__icon i {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 26px;
	line-height: 1;
	color: #ee5a24;
}

.profile-action-card__content {
	min-width: 0;
}

.profile-action-card__content span {
	display: inline-flex;
	align-items: center;
	border-radius: 999px;
	background: #f8fafc;
	color: #6f7d95;
	font-size: 10px;
	font-weight: 900;
	padding: 4px 9px;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 7px;
}

.profile-action-card__content h4 {
	margin: 0;
	color: #071b33;
	font-size: 17px;
	font-weight: 900;
}

.profile-action-card__content p {
	margin: 7px 0 13px 0;
	color: #6f7d95;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.45;
}

/* =========================================================
   Fiche personnelle - bloc RGPD explicite
   ========================================================= */

.profile-rgpd-card {
	background: #ffffff;
	border: 1px solid #ffd4bd;
	border-radius: 22px;
	padding: 18px;
	box-shadow: 0 10px 28px rgba(238, 90, 36, .08);
}

.profile-rgpd-card__header {
	display: grid;
	grid-template-columns: 54px 1fr;
	gap: 14px;
	align-items: flex-start;
	margin-bottom: 14px;
}

.profile-rgpd-card__icon {
	width: 54px;
	height: 54px;
	border-radius: 17px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 25px;
}

.profile-rgpd-card h4 {
	margin: 7px 0 0 0;
	color: #071b33;
	font-size: 17px;
	font-weight: 900;
}

.profile-rgpd-status {
	display: inline-flex;
	align-items: center;
	border-radius: 999px;
	font-size: 10px;
	font-weight: 900;
	padding: 4px 9px;
	text-transform: uppercase;
	letter-spacing: .04em;
}

.profile-rgpd-status--yes {
	background: #e8fff6;
	color: #087f5b;
	border: 1px solid #b8f3dc;
}

.profile-rgpd-status--no {
	background: #fff0f0;
	color: #b42318;
	border: 1px solid #ffd0d0;
}

.profile-rgpd-card__body p {
	margin: 0 0 10px 0;
	color: #41516a;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.5;
}

.profile-rgpd-card__body ul {
	margin: 0 0 14px 0;
	padding-left: 18px;
	color: #41516a;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.45;
}

.profile-rgpd-card__body li {
	margin-bottom: 6px;
}

.profile-rgpd-card__body li:last-child {
	margin-bottom: 0;
}

@media (max-width: 700px) {
	.profile-rgpd-card__header {
		grid-template-columns: 1fr;
	}

	.profile-rgpd-card__icon {
		width: 48px;
		height: 48px;
	}
}
/* =========================================================
   Mes affiliations
   ========================================================= */

.my-affiliations-page {
	max-width: 1180px;
	margin: 0 auto;
}

.current-affiliation-card {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 24px;
	padding: 24px;
	margin-bottom: 18px;
	box-shadow: 0 12px 35px rgba(15, 34, 54, .06);
	overflow: hidden;
	position: relative;
}

.current-affiliation-card::after {
	content: "";
	position: absolute;
	right: -70px;
	top: -90px;
	width: 220px;
	height: 220px;
	border-radius: 50%;
	background: rgba(238, 90, 36, .08);
	pointer-events: none;
}

.current-affiliation-card__header {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 22px;
	position: relative;
	z-index: 1;
}

.current-affiliation-icon {
	width: 56px;
	height: 56px;
	border-radius: 18px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 26px;
}

.current-affiliation-card__header span {
	display: inline-flex;
	background: #fff4ec;
	color: #ee5a24;
	border-radius: 999px;
	padding: 5px 10px;
	font-size: 11px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 6px;
}

.current-affiliation-card__header h3 {
	margin: 0;
	color: #071b33;
	font-size: 24px;
	font-weight: 900;
	line-height: 1;
}

.current-affiliation-main {
	display: grid;
	grid-template-columns: 1.2fr 1fr;
	gap: 18px;
	margin-bottom: 20px;
	position: relative;
	z-index: 1;
}

.current-affiliation-player,
.current-affiliation-club {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 20px;
	padding: 18px;
}

.current-affiliation-player {
	display: flex;
	align-items: center;
	gap: 14px;
}

.current-affiliation-avatar {
	width: 58px;
	height: 58px;
	min-width: 58px;
	border-radius: 18px;
	background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%);
	color: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 900;
	font-size: 17px;
	box-shadow: 0 12px 25px rgba(238, 90, 36, .20);
}

.current-affiliation-player span,
.current-affiliation-club span {
	display: block;
	color: #6f7d95;
	font-size: 11px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 5px;
}

.current-affiliation-player h4 {
	margin: 0;
	color: #071b33;
	font-size: 20px;
	font-weight: 900;
}

.current-affiliation-player p {
	margin: 5px 0 0 0;
	color: #6f7d95;
	font-size: 13px;
	font-weight: 700;
}

.current-affiliation-club strong {
	display: block;
	color: #071b33;
	font-size: 18px;
	font-weight: 900;
	line-height: 1.35;
}

.affiliation-stats-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 12px;
	margin-bottom: 20px;
	position: relative;
	z-index: 1;
}

.affiliation-stat-card {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 16px;
}

.affiliation-stat-card i {
	width: 38px;
	height: 38px;
	border-radius: 13px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 19px;
	margin-bottom: 12px;
}

.affiliation-stat-card span {
	display: block;
	color: #6f7d95;
	font-size: 11px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 6px;
}

.affiliation-stat-card strong {
	display: block;
	color: #071b33;
	font-size: 16px;
	font-weight: 900;
	line-height: 1.25;
}

.affiliation-stat-card--ranking strong {
	color: #ee5a24;
	font-size: 22px;
}

.affiliation-functions-block {
	position: relative;
	z-index: 1;
	background: #071b33;
	border-radius: 20px;
	padding: 18px;
}

.affiliation-functions-block h4 {
	margin: 0 0 14px 0;
	color: #ffffff;
	font-size: 16px;
	font-weight: 900;
}

.affiliation-functions-list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10px;
}

.affiliation-function-item {
	background: rgba(255,255,255,.08);
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 16px;
	padding: 14px;
	display: flex;
	gap: 10px;
	align-items: flex-start;
}

.affiliation-function-item i {
	width: 34px;
	height: 34px;
	min-width: 34px;
	border-radius: 12px;
	background: rgba(255,255,255,.10);
	color: #ff8a00;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 17px;
}

.affiliation-function-item strong {
	display: block;
	color: #ffffff;
	font-size: 12px;
	font-weight: 900;
	margin-bottom: 4px;
}

.affiliation-function-item span {
	display: block;
	color: rgba(255,255,255,.76);
	font-size: 12px;
	font-weight: 700;
	line-height: 1.35;
}

.affiliations-timeline {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.affiliation-history-card {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 22px;
	padding: 18px;
	display: grid;
	grid-template-columns: 150px 1fr;
	gap: 18px;
	box-shadow: 0 10px 28px rgba(15, 34, 54, .04);
	transition: .2s ease;
}

.affiliation-history-card:hover {
	border-color: rgba(238, 90, 36, .25);
	box-shadow: 0 16px 34px rgba(15, 34, 54, .07);
	transform: translateY(-1px);
}

.affiliation-history-season {
	background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%);
	border-radius: 18px;
	color: #ffffff;
	padding: 18px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	text-align: center;
}

.affiliation-history-season span {
	font-size: 11px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .05em;
	opacity: .86;
	margin-bottom: 6px;
}

.affiliation-history-season strong {
	font-size: 20px;
	font-weight: 900;
	line-height: 1.1;
}

.affiliation-history-content {
	min-width: 0;
}

.affiliation-history-main {
	display: grid;
	grid-template-columns: 1.4fr .6fr .6fr;
	gap: 10px;
	margin-bottom: 12px;
}

.affiliation-history-main div {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 16px;
	padding: 14px;
}

.affiliation-history-main span {
	display: block;
	color: #6f7d95;
	font-size: 10px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 6px;
}

.affiliation-history-main strong {
	display: block;
	color: #071b33;
	font-size: 14px;
	font-weight: 900;
	line-height: 1.3;
}

.affiliation-history-functions {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10px;
}

.affiliation-history-functions div {
	background: #fff4ec;
	border: 1px solid #ffd4bd;
	border-radius: 16px;
	padding: 12px;
	display: flex;
	gap: 10px;
	align-items: flex-start;
}

.affiliation-history-functions i {
	width: 32px;
	height: 32px;
	min-width: 32px;
	border-radius: 11px;
	background: #ffffff;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 16px;
}

.affiliation-history-functions strong {
	display: block;
	color: #071b33;
	font-size: 12px;
	font-weight: 900;
	margin-bottom: 3px;
}

.affiliation-history-functions em {
	display: block;
	color: #6f7d95;
	font-size: 12px;
	font-weight: 700;
	font-style: normal;
	line-height: 1.35;
}

@media (max-width: 1000px) {
	.current-affiliation-main,
	.affiliation-stats-grid,
	.affiliation-functions-list,
	.affiliation-history-main,
	.affiliation-history-functions {
		grid-template-columns: 1fr;
	}

	.affiliation-history-card {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 600px) {
	.current-affiliation-card {
		padding: 18px;
	}

	.current-affiliation-player {
		align-items: flex-start;
	}

	.affiliation-history-season {
		text-align: left;
	}

	.affiliation-history-season strong {
		font-size: 18px;
	}
}
/* =========================================================
   Discipline
   ========================================================= */

.discipline-modern-page {
	max-width: 1180px;
	margin: 0 auto;
}

.discipline-select-zone {
	width: min(620px, 100%);
}

.discipline-select-form {
	display: flex;
	align-items: center;
	gap: 12px;
	width: 100%;
}

.discipline-select-form select {
	flex: 1;
	min-width: 0;
}

.discipline-file-card {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 24px;
	padding: 24px;
	margin-bottom: 18px;
	box-shadow: 0 12px 35px rgba(15, 34, 54, .06);
	position: relative;
	overflow: hidden;
}

.discipline-file-card::after {
	content: "";
	position: absolute;
	right: -70px;
	top: -90px;
	width: 220px;
	height: 220px;
	border-radius: 50%;
	background: rgba(238, 90, 36, .08);
	pointer-events: none;
}

.discipline-file-card__header {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 22px;
	position: relative;
	z-index: 1;
}

.discipline-file-icon {
	width: 58px;
	height: 58px;
	border-radius: 18px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 28px;
}

.discipline-file-card__header span {
	display: inline-flex;
	background: #fff4ec;
	color: #ee5a24;
	border-radius: 999px;
	padding: 5px 10px;
	font-size: 11px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 6px;
}

.discipline-file-card__header h3 {
	margin: 0;
	color: #071b33;
	font-size: 24px;
	font-weight: 900;
	line-height: 1.15;
}

.discipline-file-card__header p {
	margin: 5px 0 0 0;
	color: #6f7d95;
	font-size: 13px;
	font-weight: 700;
}

.discipline-summary-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 12px;
	position: relative;
	z-index: 1;
}

.discipline-summary-item {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 16px;
}

.discipline-summary-item i {
	width: 38px;
	height: 38px;
	border-radius: 13px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 19px;
	margin-bottom: 12px;
}

.discipline-summary-item span {
	display: block;
	color: #6f7d95;
	font-size: 11px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 6px;
}

.discipline-summary-item strong {
	display: block;
	color: #071b33;
	font-size: 16px;
	font-weight: 900;
	line-height: 1.25;
}

.discipline-grid {
	display: grid;
	grid-template-columns: 1.2fr .8fr;
	gap: 18px;
	margin-bottom: 18px;
}

.discipline-info-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-bottom: 18px;
}

.discipline-info-list div {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 16px;
	padding: 14px;
	display: flex;
	justify-content: space-between;
	gap: 14px;
}

.discipline-info-list strong {
	color: #071b33;
	font-size: 13px;
	font-weight: 900;
}

.discipline-info-list span {
	color: #6f7d95;
	font-size: 13px;
	font-weight: 700;
	text-align: right;
}

.discipline-report-box {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 18px;
	margin-bottom: 14px;
}

.discipline-report-box strong {
	display: block;
	color: #071b33;
	font-size: 14px;
	font-weight: 900;
	margin-bottom: 8px;
}

.discipline-report-box p {
	margin: 0;
	color: #41516a;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.6;
}

.discipline-document-btn {
	border-radius: 14px;
	background: #071b33;
	color: #ffffff !important;
	padding: 11px 14px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	font-weight: 900;
	text-decoration: none !important;
	transition: .2s ease;
}

.discipline-document-btn:hover {
	background: #0d2f4f;
	transform: translateY(-1px);
}

.discipline-suspension-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.discipline-suspension-list div {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 16px;
	padding: 14px;
	display: flex;
	align-items: center;
	gap: 10px;
	color: #6f7d95;
	font-size: 13px;
	font-weight: 800;
}

.discipline-suspension-list div.active {
	background: #fff0f0;
	border-color: #ffd0d0;
	color: #b42318;
}

.discipline-suspension-list i {
	width: 34px;
	height: 34px;
	min-width: 34px;
	border-radius: 12px;
	background: #ffffff;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 17px;
}

.discipline-suspension-list div.active i {
	color: #b42318;
}

.discipline-follow-list {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.discipline-follow-card {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 20px;
	padding: 18px;
	box-shadow: 0 10px 28px rgba(15, 34, 54, .04);
}

.discipline-follow-card__header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 14px;
	margin-bottom: 14px;
}

.discipline-follow-card__header span {
	display: inline-flex;
	background: #fff4ec;
	color: #ee5a24;
	border-radius: 999px;
	padding: 5px 10px;
	font-size: 11px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 7px;
}

.discipline-follow-card__header h4 {
	margin: 0;
	color: #071b33;
	font-size: 18px;
	font-weight: 900;
}

.discipline-follow-card__header a {
	border-radius: 13px;
	background: #071b33;
	color: #ffffff !important;
	padding: 9px 12px;
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-size: 12px;
	font-weight: 900;
	text-decoration: none !important;
	white-space: nowrap;
}

.discipline-follow-report {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 16px;
	padding: 14px;
	color: #41516a;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.6;
}

.discipline-empty-box {
	background: #e8fff6;
	border: 1px solid #b8f3dc;
	border-radius: 18px;
	padding: 18px;
	display: flex;
	gap: 14px;
	align-items: flex-start;
	color: #087f5b;
}

.discipline-empty-box i {
	width: 42px;
	height: 42px;
	min-width: 42px;
	border-radius: 14px;
	background: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
}

.discipline-empty-box strong {
	display: block;
	font-size: 15px;
	font-weight: 900;
	margin-bottom: 4px;
}

.discipline-empty-box span {
	display: block;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.45;
}

.discipline-empty-box--large {
	margin-top: 0;
}

@media (max-width: 1000px) {
	.discipline-summary-grid,
	.discipline-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 700px) {
	.discipline-select-form {
		flex-direction: column;
		align-items: stretch;
	}

	.discipline-info-list div {
		flex-direction: column;
	}

	.discipline-info-list span {
		text-align: left;
	}

	.discipline-follow-card__header {
		flex-direction: column;
	}

	.discipline-follow-card__header a {
		width: 100%;
		justify-content: center;
	}
}
/* =========================================================
   Agenda des formations
   ========================================================= */

.training-modern-page {
	max-width: 1180px;
	margin: 0 auto;
}

.training-list {
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.training-card {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 24px;
	padding: 20px;
	display: grid;
	grid-template-columns: 110px 1fr;
	gap: 20px;
	box-shadow: 0 10px 28px rgba(15, 34, 54, .05);
	transition: .2s ease;
}

.training-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 16px 36px rgba(15, 34, 54, .08);
	border-color: rgba(238, 90, 36, .25);
}

.training-card__type {
	background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%);
	color: #ffffff;
	border-radius: 22px;
	min-height: 110px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	box-shadow: 0 14px 30px rgba(238, 90, 36, .22);
}

.training-card--msin .training-card__type {
	background: linear-gradient(135deg, #071b33 0%, #0d2f4f 100%);
	box-shadow: 0 14px 30px rgba(7, 27, 51, .18);
}

.training-card__type span {
	font-size: 24px;
	font-weight: 900;
	line-height: 1.1;
}

.training-card__content {
	min-width: 0;
}

.training-card__header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 16px;
	margin-bottom: 16px;
}

.training-organizer {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	border-radius: 999px;
	background: #fff4ec;
	color: #ee5a24;
	font-size: 11px;
	font-weight: 900;
	padding: 6px 10px;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 8px;
}

.training-card--msin .training-organizer {
	background: #eef4ff;
	color: #2457c5;
}

.training-card__header h4 {
	margin: 0;
	color: #071b33;
	font-size: 22px;
	font-weight: 900;
	line-height: 1.25;
}

.training-card__header p {
	margin: 6px 0 0 0;
	color: #6f7d95;
	font-size: 13px;
	font-weight: 700;
}

.training-card__header p strong {
	color: #071b33;
	font-weight: 900;
}

.training-price-box {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 14px 18px;
	text-align: center;
	min-width: 105px;
}

.training-price-box span {
	display: block;
	color: #6f7d95;
	font-size: 10px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 5px;
}

.training-price-box strong {
	display: block;
	color: #ee5a24;
	font-size: 22px;
	font-weight: 900;
	line-height: 1;
}

.training-meta-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
	margin-bottom: 16px;
}

.training-meta-item {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 14px;
	display: flex;
	gap: 12px;
	align-items: flex-start;
}

.training-meta-item i {
	width: 38px;
	height: 38px;
	min-width: 38px;
	border-radius: 13px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 19px;
}

.training-meta-item strong {
	display: block;
	color: #071b33;
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .03em;
	margin-bottom: 4px;
}

.training-meta-item span {
	display: block;
	color: #6f7d95;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.35;
}

.training-dates-block {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 16px;
	margin-bottom: 16px;
}

.training-dates-block > strong {
	display: block;
	color: #071b33;
	font-size: 14px;
	font-weight: 900;
	margin-bottom: 12px;
}

.training-dates-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.training-date-item {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 16px;
	padding: 14px;
	display: grid;
	grid-template-columns: 44px 1fr;
	gap: 12px;
}

.training-date-item__icon {
	width: 44px;
	height: 44px;
	border-radius: 15px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 21px;
}

.training-date-item h5 {
	margin: 0 0 8px 0;
	color: #071b33;
	font-size: 15px;
	font-weight: 900;
}

.training-date-item span {
	display: flex;
	align-items: flex-start;
	gap: 6px;
	color: #6f7d95;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.4;
	margin-bottom: 4px;
}

.training-date-item span:last-child {
	margin-bottom: 0;
}

.training-date-item span i {
	color: #ee5a24;
	font-size: 15px;
	margin-top: 1px;
}

.training-date-empty {
	background: #fff7ed;
	border: 1px solid #ffd4b4;
	border-radius: 16px;
	padding: 14px;
	display: flex;
	gap: 10px;
	align-items: flex-start;
	color: #9a4a00;
	font-size: 13px;
	font-weight: 800;
}

.training-date-empty i {
	font-size: 18px;
	margin-top: 1px;
}

.training-action-zone {
	display: flex;
	justify-content: flex-end;
}

.training-warning {
	background: #fff7ed;
	border: 1px solid #ffd4b4;
	border-radius: 18px;
	padding: 16px;
	display: flex;
	align-items: flex-start;
	gap: 12px;
	color: #9a4a00;
	width: 100%;
}

.training-warning i {
	width: 40px;
	height: 40px;
	min-width: 40px;
	border-radius: 14px;
	background: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 21px;
}

.training-warning strong {
	display: block;
	font-size: 14px;
	font-weight: 900;
	margin-bottom: 4px;
}

.training-warning span {
	display: block;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.45;
}

@media (max-width: 900px) {
	.training-card {
		grid-template-columns: 1fr;
	}

	.training-card__type {
		min-height: auto;
		padding: 18px;
		justify-content: flex-start;
	}

	.training-card__header {
		flex-direction: column;
	}

	.training-price-box {
		width: 100%;
		text-align: left;
	}

	.training-meta-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 600px) {
	.training-date-item {
		grid-template-columns: 1fr;
	}

	.training-date-item__icon {
		width: 42px;
		height: 42px;
	}

	.training-action-zone form,
	.training-action-zone .btn-affiliation-main {
		width: 100%;
	}
}
/* =========================================================
   Mes inscriptions aux formations
   ========================================================= */

.training-status-box {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 14px 18px;
	text-align: center;
	min-width: 145px;
}

.training-status-box span {
	display: block;
	color: #6f7d95;
	font-size: 10px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 5px;
}

.training-status-box strong {
	display: block;
	color: #9a4a00;
	font-size: 15px;
	font-weight: 900;
	line-height: 1.2;
}

.training-status-box--validated {
	background: #e8fff6;
	border-color: #b8f3dc;
}

.training-status-box--validated strong {
	color: #087f5b;
}

.training-status-box--pending {
	background: #fff7ed;
	border-color: #ffd4b4;
}

.training-supports-block {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 16px;
	margin-bottom: 16px;
}

.training-supports-block > strong {
	display: block;
	color: #071b33;
	font-size: 14px;
	font-weight: 900;
	margin-bottom: 12px;
}

.training-supports-list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.training-support-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	border-radius: 14px;
	background: #071b33;
	color: #ffffff !important;
	padding: 10px 13px;
	font-size: 12px;
	font-weight: 900;
	text-decoration: none !important;
	transition: .2s ease;
}

.training-support-btn:hover {
	background: #0d2f4f;
	transform: translateY(-1px);
}

.training-info-summary {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 16px;
	padding: 16px;
	margin-bottom: 14px;
}

.training-info-main {
	margin-bottom: 14px;
}

.training-info-main h5 {
	margin: 0;
	color: #071b33;
	font-size: 17px;
	font-weight: 900;
}

.training-info-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 10px;
}

.training-info-grid div {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 14px;
	padding: 12px;
}

.training-info-grid strong {
	display: block;
	color: #6f7d95;
	font-size: 10px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 5px;
}

.training-info-grid span {
	display: block;
	color: #071b33;
	font-size: 13px;
	font-weight: 900;
	line-height: 1.25;
}

.training-card--af .training-card__type {
	background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%);
	box-shadow: 0 14px 30px rgba(238, 90, 36, .22);
}

@media (max-width: 900px) {
	.training-info-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.training-status-box {
		width: 100%;
		text-align: left;
	}
}

@media (max-width: 600px) {
	.training-info-grid {
		grid-template-columns: 1fr;
	}

	.training-support-btn {
		width: 100%;
		justify-content: center;
	}
}
/* =========================================================
   Contact
   ========================================================= */

.contact-modern-page {
	max-width: 1280px;
	margin: 0 auto;
}

.contact-main-grid,
.contact-directory-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px;
	margin-bottom: 18px;
}

.contact-info-list {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.contact-info-item {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 16px;
	display: flex;
	align-items: flex-start;
	gap: 14px;
}

.contact-info-item__icon {
	width: 46px;
	height: 46px;
	min-width: 46px;
	border-radius: 15px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 23px;
}

.contact-info-item strong {
	display: block;
	color: #071b33;
	font-size: 14px;
	font-weight: 900;
	margin-bottom: 5px;
}

.contact-info-item span,
.contact-info-item a {
	display: block;
	color: #6f7d95;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.45;
	text-decoration: none;
}

.contact-info-item a:hover {
	color: #ee5a24;
}

.contact-form {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.contact-person-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.contact-person-card {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 20px;
	padding: 14px;
	display: grid;
	grid-template-columns: 62px 1fr;
	gap: 14px;
	align-items: flex-start;
	box-shadow: 0 8px 22px rgba(15, 34, 54, .04);
	transition: .2s ease;
}

.contact-person-card:hover {
	transform: translateY(-1px);
	border-color: rgba(238, 90, 36, .25);
	box-shadow: 0 14px 28px rgba(15, 34, 54, .07);
}

.contact-person-card img {
	width: 62px;
	height: 62px;
	border-radius: 18px;
	object-fit: cover;
	background: #fff4ec;
}

.contact-person-card__content {
	min-width: 0;
}

.contact-person-card__content > span {
	display: inline-flex;
	align-items: center;
	background: #fff4ec;
	color: #ee5a24;
	border-radius: 999px;
	padding: 4px 9px;
	font-size: 10px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 6px;
}

.contact-person-card__content h4 {
	margin: 0;
	color: #071b33;
	font-size: 16px;
	font-weight: 900;
	line-height: 1.2;
}

.contact-person-card__content p {
	margin: 4px 0 7px 0;
	color: #6f7d95;
	font-size: 12px;
	font-weight: 800;
	line-height: 1.35;
}

.contact-person-card__content a {
	display: flex;
	align-items: center;
	gap: 6px;
	color: #41516a;
	font-size: 12px;
	font-weight: 800;
	line-height: 1.35;
	text-decoration: none;
	word-break: break-word;
	margin-top: 5px;
}

.contact-person-card__content a i {
	color: #ee5a24;
	font-size: 15px;
}

.contact-person-card__content a:hover {
	color: #ee5a24;
}

@media (max-width: 991px) {
	.contact-main-grid,
	.contact-directory-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 600px) {
	.contact-person-card {
		grid-template-columns: 1fr;
	}

	.contact-person-card img {
		width: 56px;
		height: 56px;
	}

	.contact-info-item {
		flex-direction: column;
	}
}
/* =========================================================
   Modification du mot de passe
   ========================================================= */

.password-modern-page {
	max-width: 1280px;
	margin: 0 auto;
}

.password-form {
	margin: 0;
}

.password-info-box {
	background: #fff7ed;
	border: 1px solid #ffd4b4;
	border-radius: 18px;
	padding: 16px;
	display: flex;
	align-items: flex-start;
	gap: 12px;
	color: #9a4a00;
	margin-bottom: 20px;
}

.password-info-box i {
	width: 40px;
	height: 40px;
	min-width: 40px;
	border-radius: 14px;
	background: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 21px;
}

.password-info-box strong {
	display: block;
	font-size: 14px;
	font-weight: 900;
	margin-bottom: 4px;
}

.password-info-box span {
	display: block;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.45;
}

.password-input-wrapper {
	position: relative;
}

.password-input-wrapper input {
	padding-right: 48px;
}

.password-input-wrapper > i {
	position: absolute;
	right: 14px;
	top: 50%;
	transform: translateY(-50%);
	width: 28px;
	height: 28px;
	border-radius: 10px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 15px;
	pointer-events: none;
}

.password-rules-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
	margin-bottom: 20px;
}

.password-rule-card {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 16px;
	padding: 14px;
	display: flex;
	align-items: flex-start;
	gap: 10px;
	color: #41516a;
	font-size: 12px;
	font-weight: 800;
	line-height: 1.4;
}

.password-rule-card i {
	width: 30px;
	height: 30px;
	min-width: 30px;
	border-radius: 11px;
	background: #e8fff6;
	color: #087f5b;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 15px;
}

.password-advice-card {
	background: #071b33;
	color: #ffffff;
	border-radius: 22px;
	padding: 18px;
	display: grid;
	grid-template-columns: 54px 1fr;
	gap: 14px;
	box-shadow: 0 10px 28px rgba(7, 27, 51, .12);
}

.password-advice-card__icon {
	width: 54px;
	height: 54px;
	border-radius: 17px;
	background: rgba(255,255,255,.10);
	color: #ff8a00;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 25px;
}

.password-advice-card h4 {
	margin: 0 0 7px 0;
	color: #ffffff;
	font-size: 17px;
	font-weight: 900;
}

.password-advice-card p {
	margin: 0;
	color: rgba(255,255,255,.75);
	font-size: 12px;
	font-weight: 700;
	line-height: 1.45;
}

@media (max-width: 900px) {
	.password-rules-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 700px) {
	.password-advice-card {
		grid-template-columns: 1fr;
	}

	.password-advice-card__icon {
		width: 48px;
		height: 48px;
	}
}
/* =========================================================
   Club - Mes affiliés
   ========================================================= */

.club-members-page {
	max-width: 1280px;
	margin: 0 auto;
}

.club-members-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: flex-end;
}

.club-members-search {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 18px;
	padding: 12px;
	display: grid;
	grid-template-columns: 46px 1fr;
	gap: 12px;
	align-items: center;
	margin-bottom: 18px;
}

.club-members-search__icon {
	width: 46px;
	height: 46px;
	border-radius: 15px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
}

.club-members-search input {
	border: 0 !important;
	background: #ffffff;
	border-radius: 14px;
	min-height: 46px;
	font-weight: 700;
	color: #071b33;
}

.club-members-search input:focus {
	box-shadow: 0 0 0 3px rgba(238, 90, 36, .10);
}

.club-members-table-wrapper {
	border-radius: 18px;
}

.club-members-table th,
.club-members-table td {
	vertical-align: middle !important;
}

.club-member-licence {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	background: #eef4ff;
	color: #2457c5;
	border: 1px solid #cfe0ff;
	padding: 7px 11px;
	font-size: 12px;
	font-weight: 900;
}

.club-ranking-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	border-radius: 999px;
	background: #fff4ec;
	color: #ee5a24;
	border: 1px solid #ffd4bd;
	padding: 7px 10px;
	font-size: 12px;
	font-weight: 900;
}

.club-ranking-badge--women {
	background: #f0fff8;
	color: #087f5b;
	border-color: #b8f3dc;
}

.club-simple-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	background: #f8fafc;
	color: #41516a;
	border: 1px solid #edf1f7;
	padding: 7px 10px;
	font-size: 12px;
	font-weight: 900;
	white-space: nowrap;
}

.club-simple-badge--status {
	background: #fff7ed;
	color: #9a4a00;
	border-color: #ffd4b4;
}

.club-member-suspended {
	display: inline-flex !important;
	align-items: center;
	gap: 5px;
	border-radius: 999px;
	background: #fff0f0;
	color: #b42318 !important;
	border: 1px solid #ffd0d0;
	padding: 4px 8px;
	font-size: 11px !important;
	font-weight: 900 !important;
	margin-top: 4px;
}

.club-status-pill,
.club-confirmation-pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	padding: 7px 11px;
	font-size: 11px;
	font-weight: 900;
	white-space: nowrap;
	text-transform: uppercase;
	letter-spacing: .03em;
}

.club-status-pill--yes,
.club-confirmation-pill--confirmed {
	background: #e8fff6;
	color: #087f5b;
	border: 1px solid #b8f3dc;
}

.club-status-pill--no,
.club-confirmation-pill--not-confirmed {
	background: #fff0f0;
	color: #b42318;
	border: 1px solid #ffd0d0;
}

.club-status-pill--neutral,
.club-confirmation-pill--pending {
	background: #fff7ed;
	color: #9a4a00;
	border: 1px solid #ffd4b4;
}

.club-edit-btn {
	border: 0;
	border-radius: 13px;
	background: #071b33;
	color: #ffffff;
	padding: 9px 12px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	font-size: 12px;
	font-weight: 900;
	cursor: pointer;
	transition: .2s ease;
}

.club-edit-btn:hover {
	background: #0d2f4f;
	transform: translateY(-1px);
}

@media (max-width: 991px) {
	.club-members-actions {
		justify-content: flex-start;
		width: 100%;
	}

	.club-members-actions .aff-action-btn {
		flex: 1;
		justify-content: center;
	}
}

@media (max-width: 700px) {
	.club-members-search {
		grid-template-columns: 1fr;
	}

	.club-members-search__icon {
		width: 42px;
		height: 42px;
	}

	.club-members-table-wrapper {
		overflow-x: auto;
	}

	.club-members-actions .aff-action-btn {
		width: 100%;
	}
}
/* =========================================================
   Club - édition affilié
   ========================================================= */

.club-edit-player-page {
	max-width: 1180px;
	margin: 0 auto;
}

.club-edit-player-summary {
	background: #ffffff;
	border: 1px solid #edf1f7;
	border-radius: 24px;
	padding: 22px;
	margin-bottom: 18px;
	display: grid;
	grid-template-columns: 74px 1fr auto;
	gap: 18px;
	align-items: center;
	box-shadow: 0 12px 35px rgba(15, 34, 54, .06);
}

.club-edit-player-summary__avatar {
	width: 74px;
	height: 74px;
	border-radius: 24px;
	background: linear-gradient(135deg, #ee5a24 0%, #ff8a00 100%);
	color: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	font-weight: 900;
	box-shadow: 0 14px 30px rgba(238, 90, 36, .20);
}

.club-edit-player-summary__content span {
	display: inline-flex;
	background: #fff4ec;
	color: #ee5a24;
	border-radius: 999px;
	padding: 5px 10px;
	font-size: 11px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 7px;
}

.club-edit-player-summary__content h3 {
	margin: 0;
	color: #071b33;
	font-size: 24px;
	font-weight: 900;
	line-height: 1.15;
}

.club-edit-player-summary__content p {
	margin: 6px 0 0 0;
	color: #6f7d95;
	font-size: 13px;
	font-weight: 700;
}

.club-edit-player-summary__badges {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 8px;
}

.club-edit-player-summary__badges span {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: #f8fafc;
	border: 1px solid #edf1f7;
	color: #41516a;
	border-radius: 999px;
	padding: 8px 11px;
	font-size: 12px;
	font-weight: 900;
}

.club-edit-player-summary__badges i {
	color: #ee5a24;
}

/* Suspensions */

.club-player-suspension-alert {
	background: #fff7ed;
	border: 1px solid #ffd4b4;
	border-radius: 24px;
	padding: 20px;
	margin-bottom: 18px;
	display: grid;
	grid-template-columns: 58px 1fr;
	gap: 16px;
	color: #9a4a00;
}

.club-player-suspension-alert__icon {
	width: 58px;
	height: 58px;
	border-radius: 18px;
	background: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 28px;
	color: #ee5a24;
}

.club-player-suspension-alert__content h3 {
	margin: 0 0 8px 0;
	color: #9a4a00;
	font-size: 20px;
	font-weight: 900;
}

.club-player-suspension-alert__content p {
	margin: 0 0 14px 0;
	color: #9a4a00;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.55;
}

.club-player-suspension-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 8px;
	margin-bottom: 14px;
}

.club-player-suspension-grid div {
	background: #ffffff;
	border: 1px solid #ffd4b4;
	border-radius: 14px;
	padding: 10px;
}

.club-player-suspension-grid span {
	display: block;
	color: #9a4a00;
	font-size: 10px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .03em;
	margin-bottom: 4px;
}

.club-player-suspension-grid strong {
	display: block;
	color: #071b33;
	font-size: 14px;
	font-weight: 900;
}

.club-player-suspension-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	border-radius: 14px;
	background: #071b33;
	color: #ffffff !important;
	padding: 10px 13px;
	font-size: 12px;
	font-weight: 900;
	text-decoration: none !important;
	transition: .2s ease;
}

.club-player-suspension-link:hover {
	background: #0d2f4f;
	transform: translateY(-1px);
}

/* Formulaire */

.club-edit-player-form {
	margin: 0;
}

.club-input-with-icon {
	position: relative;
	width: 100%;
}

.club-input-with-icon .club-input-icon {
	position: absolute;
	left: 14px;
	top: 50%;
	transform: translateY(-50%);
	width: 30px;
	height: 30px;
	border-radius: 10px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 3;
	pointer-events: none;
}

.club-input-with-icon .club-input-icon i {
	position: static;
	transform: none;
	font-size: 16px;
	line-height: 1;
	color: #ee5a24;
}

.club-input-with-icon input {
	padding-left: 56px !important;
}

.club-readonly-email {
	background: #f8fafc;
	border: 1px solid #edf1f7;
	border-radius: 16px;
	padding: 14px;
	display: grid;
	grid-template-columns: 42px 1fr;
	gap: 12px;
	align-items: flex-start;
}

.club-readonly-email > i {
	width: 42px;
	height: 42px;
	border-radius: 14px;
	background: #fff4ec;
	color: #ee5a24;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
}

.club-readonly-email strong {
	display: block;
	color: #071b33;
	font-size: 14px;
	font-weight: 900;
	line-height: 1.35;
	word-break: break-word;
}

.club-readonly-email span {
	display: block;
	color: #6f7d95;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.45;
	margin-top: 4px;
}

/* Radios handisport */

.club-radio-modern {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.club-radio-modern label {
	margin: 0;
	cursor: pointer;
}

.club-radio-modern input {
	display: none;
}

.club-radio-modern span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 100px;
	border-radius: 999px;
	background: #f8fafc;
	border: 1px solid #edf1f7;
	color: #41516a;
	padding: 10px 16px;
	font-size: 13px;
	font-weight: 900;
	transition: .2s ease;
}

.club-radio-modern input:checked + span {
	background: #fff4ec;
	border-color: #ffd4bd;
	color: #ee5a24;
	box-shadow: 0 8px 18px rgba(238, 90, 36, .10);
}

/* Message d'avertissement */

.club-edit-warning {
	background: #fff7ed;
	border: 1px solid #ffd4b4;
	border-radius: 18px;
	padding: 16px;
	display: flex;
	align-items: flex-start;
	gap: 12px;
	color: #9a4a00;
	margin-bottom: 20px;
}

.club-edit-warning i {
	width: 40px;
	height: 40px;
	min-width: 40px;
	border-radius: 14px;
	background: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 21px;
}

.club-edit-warning strong {
	display: block;
	font-size: 14px;
	font-weight: 900;
	margin-bottom: 4px;
}

.club-edit-warning span {
	display: block;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.45;
}

/* Chosen */

.club-edit-player-page .chosen-container {
	width: 100% !important;
}

.club-edit-player-page .chosen-container-single .chosen-single {
	height: 46px;
	border-radius: 14px;
	border: 1px solid #edf1f7;
	background: #ffffff;
	box-shadow: none;
	display: flex;
	align-items: center;
	padding: 0 14px;
	color: #071b33;
	font-weight: 700;
}

.club-edit-player-page .chosen-container-single .chosen-single div {
	top: 50%;
	transform: translateY(-50%);
}

/* Responsive */

@media (max-width: 1000px) {
	.club-edit-player-summary {
		grid-template-columns: 74px 1fr;
	}

	.club-edit-player-summary__badges {
		grid-column: 1 / -1;
		justify-content: flex-start;
	}

	.club-player-suspension-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 700px) {
	.club-edit-player-summary,
	.club-player-suspension-alert {
		grid-template-columns: 1fr;
	}

	.club-edit-player-summary__avatar,
	.club-player-suspension-alert__icon {
		width: 58px;
		height: 58px;
		border-radius: 18px;
	}

	.club-player-suspension-grid {
		grid-template-columns: 1fr;
	}

	.club-radio-modern {
		flex-direction: column;
	}

	.club-radio-modern label,
	.club-radio-modern span {
		width: 100%;
	}

	.club-readonly-email {
		grid-template-columns: 1fr;
	}

	.club-readonly-email > i {
		width: 40px;
		height: 40px;
	}
}
/* =========================================================
   Activation joueur - email + renvoi token
   ========================================================= */

.activation-status-email {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 8px;
	padding: 6px 9px;
	border-radius: 999px;
	background: rgba(255,255,255,.72);
	border: 1px solid rgba(15, 34, 54, .08);
	color: #41516a;
	font-size: 11px;
	font-weight: 900;
	line-height: 1.2;
	word-break: break-word;
	max-width: 100%;
}

.activation-status-email i {
	width: auto !important;
	height: auto !important;
	min-width: auto !important;
	background: transparent !important;
	color: #ee5a24 !important;
	font-size: 14px !important;
	margin: 0 !important;
}

.activation-status-email--missing {
	background: #fff0f0;
	border-color: #ffd0d0;
	color: #b42318;
}

.activation-status-email--missing i {
	color: #b42318 !important;
}

.activation-resend-form {
	margin: 10px 0 0 0;
}

.activation-resend-btn {
	border: 0;
	border-radius: 13px;
	background: #071b33;
	color: #ffffff;
	padding: 8px 11px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	font-size: 11px;
	font-weight: 900;
	cursor: pointer;
	transition: .2s ease;
}

.activation-resend-btn:hover {
	background: #0d2f4f;
	transform: translateY(-1px);
}

.activation-resend-btn i {
	width: auto !important;
	height: auto !important;
	min-width: auto !important;
	background: transparent !important;
	color: #ffffff !important;
	font-size: 14px !important;
	margin: 0 !important;
}

@media (max-width: 700px) {
	.activation-resend-btn {
		width: 100%;
	}

	.activation-status-email {
		border-radius: 12px;
		width: 100%;
	}
}