/* SPRNV Community — front-end
   Style inspiré du fil systeme.io : cartes blanches, accent bleu, doux. */

:root {
	--sprnv-blue: #003b5c;
	--sprnv-blue-dark: #002a3a;
	--sprnv-bg: #f4f6fb;
	--sprnv-card: #ffffff;
	--sprnv-border: #e6e9f0;
	--sprnv-text: #1f2937;
	--sprnv-muted: #6b7280;
	--sprnv-radius: 14px;
	--sprnv-shadow: 0 2px 10px rgba(16, 24, 40, 0.06);
}

.sprnv-feed {
	display: flex;
	padding: 50px 0;
	gap: 30px;
}

.sprnv-sidebar {
	flex: 1;
	position: sticky;
	top: 100px;
	align-self: flex-start;
}

.sprnv-feed-content {
	flex: 3;
}

/* Filtres sujets */
.sprnv-subjects {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.sprnv-sidebar-join .btn {
	display: block;
	width: 100%;
	text-align: center;
	margin-bottom: 20px;
	margin-top: 0;
}

.sprnv-sidebar-bloc {
	background: var(--sprnv-card);
	border: 1px solid var(--sprnv-border);
	box-shadow: var(--sprnv-shadow);
	padding: 20px 22px;
	margin-bottom: 18px;
}

.sprnv-subjects ul li {
	list-style-type: none;
	margin-bottom: 5px;
}

.sprnv-chip {
	display: inline-block;
	color: var(--sprnv-blue);
	text-decoration: none;
	transition: .15s;
}

.sprnv-chip:hover {
	color: var(--bleu-clair);
}

.sprnv-chip.is-active {
	color: var(--bleu-clair);
}

/* Carte post */
.sprnv-post {
	background: var(--sprnv-card);
	border: 1px solid var(--sprnv-border);
	box-shadow: var(--sprnv-shadow);
	padding: 20px 22px;
	margin-bottom: 18px;
}

.sprnv-post.is-pinned {
	border-color: #c7d2fe;
}

.sprnv-post__head {
	display: flex;
	align-items: flex-start;
	gap: 12px;
}

.sprnv-avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	flex: 0 0 44px;
	background: var(--sprnv-blue-dark);
	color: #fff;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
}

.sprnv-post__meta {
	flex: 1;
}

.sprnv-badge {
	display: inline-block;
	margin-left: 6px;
	padding: 2px 8px;
	font-size: 12px;
	background: var(--bleu-tres-clair);
	color: var(--sprnv-blue);
	border-radius: 6px;
}

.sprnv-post__sub {
	color: var(--sprnv-muted);
	font-size: 13px;
	margin-top: 2px;
}

.sprnv-post__sub strong {
	color: var(--sprnv-blue);
}

.sprnv-post__actions-top {
	display: flex;
	align-items: center;
	gap: 8px;
}

.sprnv-pin-toggle {
	background: none;
	border: 1px solid var(--sprnv-border);
	border-radius: 8px;
	padding: 4px 10px;
	font-size: 12px;
	cursor: pointer;
	color: var(--sprnv-muted);
}

.sprnv-pin-toggle:hover {
	border-color: var(--sprnv-blue);
	color: var(--sprnv-blue);
}

.sprnv-post__body {
	margin-top: 14px;
}

.sprnv-post__title {
	margin: 0 0 10px;
	font-size: 22px;
}

.sprnv-post__title a {
	color: var(--bleu-moyen);
	text-decoration: none;
}

.sprnv-post__title a:hover {
	color: var(--sprnv-blue);
}

.sprnv-post__image {
	float: right;
	margin: 0 0 12px 16px;
	max-width: 220px;
}

.sprnv-post__image img {
	width: 100%;
	border-radius: 4px;
	display: block;
}

.sprnv-post__excerpt {
	color: #374151;
	line-height: 1.6;
}

.sprnv-readmore {
	color: var(--sprnv-blue);
	font-weight: 600;
	text-decoration: none;
	display: inline-block;
	margin-top: 10px;
}

.sprnv-post__foot {
	display: flex;
	gap: 18px;
	align-items: center;
	margin-top: 16px;
	padding-top: 12px;
	border-top: 1px solid var(--sprnv-border);
	clear: both;
}

.sprnv-like,
.sprnv-comment-toggle {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	cursor: pointer;
	background: none;
	border: none;
	color: var(--sprnv-muted);
	font-size: 15px;
}

.sprnv-like.is-liked {
	color: var(--sprnv-blue);
	font-weight: 700;
}

.sprnv-like:hover,
.sprnv-comment-toggle:hover {
	color: var(--sprnv-blue);
}

/* Commentaires */
.sprnv-comments {
	margin-top: 14px;
	border-top: 1px dashed var(--sprnv-border);
	padding-top: 12px;
}

.sprnv-comment-list {
	list-style: none;
	margin: 0 0 12px;
	padding: 0;
}

.sprnv-comment {
	background: #f8fafc;
	border-radius: 10px;
	padding: 10px 12px;
	margin-bottom: 8px;
}

.sprnv-comment__date {
	color: var(--sprnv-muted);
	font-size: 12px;
	margin-left: 6px;
}

.sprnv-comment__content p {
	margin: 6px 0 0;
}

.sprnv-comment-delete {
	background: none;
	border: none;
	color: #b91c1c;
	font-size: 12px;
	cursor: pointer;
	padding: 0;
	margin-top: 4px;
}

.sprnv-comment-form textarea {
	width: 100%;
	border: 1px solid var(--sprnv-border);
	padding: 10px;
	resize: vertical;
}

.sprnv-comment-form button {
	margin-top: 8px;
}

.sprnv-comment-login a {
	color: var(--sprnv-blue);
}

/* Search */
.sprnv-search-wrapper {
	position: relative;
	display: flex;
	align-items: center;
}

.sprnv-search-btn {
	background: none;
	border: none;
	cursor: pointer;
	position: absolute;
	right: 10px;
	top: 6px;
	color: var(--bleu-clair);
}

.sprnv-search-input {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--sprnv-border);
	border-radius: 8px;
	outline: none;
}

.sprnv-search-input:focus {
	border-color: var(--sprnv-blue);
}

.sprnv-members-link {
	display: block;
	padding: 10px 12px;
	border-radius: 8px;
	background: var(--bleu-tres-clair);
	color: var(--sprnv-blue);
	text-decoration: none;
	font-weight: 600;
	text-align: center;
}

.sprnv-members-link:hover {
	background: var(--sprnv-blue);
	color: #fff;
}

/* Pagination */
.sprnv-pagination {
	display: flex;
	gap: 6px;
	justify-content: center;
	margin-top: 20px;
}

.sprnv-pagination a,
.sprnv-pagination span {
	padding: 4px 16px;
	border: 1px solid var(--sprnv-border);
	border-radius: 0;
	text-decoration: none;
	color: var(--sprnv-text);
}

.sprnv-pagination .current {
	background: var(--sprnv-blue);
	color: #fff;
	border-color: var(--sprnv-blue);
}

.sprnv-comment.is-pending {
	opacity: 0.6;
	font-style: italic;
}

.sprnv-comment-status {
	font-size: 11px;
	display: block;
}

/* Auth */
/*
.sprnv-card {
	background: var(--sprnv-card); border: 1px solid var(--sprnv-border);
	border-radius: var(--sprnv-radius); box-shadow: var(--sprnv-shadow);
	padding: 28px; max-width: 460px; margin: 0 auto;
}*/
.sprnv-auth h2 {
	margin-top: 0;
	color: white;
	margin-bottom: 20px;
}

.sprnv-form label {
	display: block;
	margin-bottom: 14px;
	font-weight: 600;
	font-size: 14px;
	color: white;
}

.sprnv-form input[type=text],
.sprnv-form input[type=email],
.sprnv-form input[type=password] {
	width: 100%;
	padding: 11px 12px;
	margin-top: 6px;
	border: 1px solid var(--sprnv-border);
	font-size: 15px;
	font-weight: 400;
}

.sprnv-form-row {
	display: flex;
	gap: 12px;
}

.sprnv-form-row label {
	flex: 1;
	color: white;
}

.sprnv-checkbox {
	font-weight: 400;
}

.sprnv-links {
	margin-top: 14px;
	font-size: 14px;
}

.sprnv-links a {
	color: var(--accent-light);
	text-decoration: none;
}

.sprnv-btn {
	background-color: var(--jaune-casse);
	color: var(--bleu-profond);
	font-family: var(--font-titre);
	font-weight: 700;
	text-transform: uppercase;
	padding: 18px 35px;
	border: none;
	cursor: pointer;
	width: auto;
	transition: all 0.3s ease;
	margin-top: 10px;
}

.sprnv-btn--primary:hover {
	transform: translateY(-3px);
	box-shadow: 0 10px 20px rgba(237, 163, 58, 0.3);
}

.sprnv-btn--ghost {
	background: transparent;
	border: 1px solid var(--sprnv-border);
	color: var(--sprnv-muted);
}

.sprnv-alert {
	padding: 12px 14px;
	border-radius: 10px;
	margin-bottom: 16px;
	font-size: 14px;
}

.sprnv-alert--error {
	background: #fef2f2;
	color: #b91c1c;
}

.sprnv-alert--success {
	background: #ecfdf5;
	color: #047857;
}

.sprnv-alert ul {
	margin: 0;
	padding-left: 18px;
}

.sprnv-role {
	color: var(--sprnv-muted);
	text-transform: capitalize;
}

.sprnv-empty {
	text-align: center;
	color: var(--sprnv-muted);
	padding: 40px;
}

/* --- Liste des membres --- */
.sprnv-members__head {
	display: flex;
	align-items: baseline;
	gap: 12px;
	margin-bottom: 20px;
}

.sprnv-members__count {
	color: var(--sprnv-muted);
	font-size: 14px;
}

.sprnv-members-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 12px;
}

.sprnv-member {
	display: flex;
	align-items: center;
	gap: 12px;
	background: var(--sprnv-card);
	border: 1px solid var(--sprnv-border);
	box-shadow: var(--sprnv-shadow);
	padding: 12px 14px;
	border-radius: var(--sprnv-radius);
}

.sprnv-member__name {
	font-weight: 600;
	color: var(--sprnv-text);
}

/* --- Mon espace --- */
.sprnv-account__header {
	display: flex;
	align-items: center;
	gap: 18px;
	flex-wrap: wrap;
	margin-bottom: 18px;
}

.sprnv-avatar--lg {
	width: 64px;
	height: 64px;
	flex: 0 0 64px;
	font-size: 22px;
}

.sprnv-account__id {
	flex: 1;
	min-width: 160px;
}

.sprnv-account__id h2 {
	margin: 0;
}

.sprnv-account__email {
	color: var(--sprnv-muted);
	margin: 4px 0 0;
	font-size: 14px;
}

.sprnv-account__nav {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.sprnv-account__edit h3 {
	margin-top: 0;
}

.sprnv-sep {
	border: none;
	border-top: 1px solid var(--sprnv-border);
	margin: 18px 0;
}

.sprnv-muted-note {
	color: var(--sprnv-muted);
	font-size: 13px;
	margin: 0 0 10px;
}

@media (max-width: 600px) {
	.sprnv-account__nav {
		width: 100%;
	}

	.sprnv-account__nav .sprnv-btn {
		flex: 1;
		text-align: center;
	}
}

@media (max-width: 600px) {
	.sprnv-post__image {
		float: none;
		margin: 0 0 12px;
		max-width: 100%;
	}

	.sprnv-form-row {
		flex-direction: column;
	}
}

.sprnv-mobile-filters {
	display: none;
}

.sprnv-mobile-nav {
	display: flex;
	gap: 6px;
	margin-bottom: 15px;
}
.sprnv-mobile-nav__link {
	flex: 1;
	text-align: center;
	padding: 8px 6px;
	border-radius: 8px;
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	color: var(--sprnv-text);
	background: var(--sprnv-bg);
}
.sprnv-mobile-nav__link.is-active {
	background: var(--sprnv-blue);
	color: #fff;
}

@media (max-width: 768px) {
	.sprnv-feed {
		gap: 0;
	}

	.sprnv-filters-toggle {
		background: transparent;
		border: none;
		display: flex;
		align-items: center;
		gap: 5px;
		font-size: 15px;
		color: var(--bleu-moyen);
	}

	.sprnv-mobile-filters .icon-search {
		transition: transform .3s ease-in-out;
	}

	.sprnv-mobile-filters.is-open .icon-search {
		transform: rotate(180deg);
	}

	.sprnv-filters-top {
		display: flex;
		align-items: center;
		gap: 10px;
		justify-content: space-between;
	}

	.sprnv-search-toggle {
		background: none;
		border: none;
		font-size: 18px;
		cursor: pointer;
	}

	/* caché par défaut */
	.sprnv-mobile-search {
		display: none;
		margin-top: 10px;
	}

	/* état ouvert */
	.sprnv-mobile-filters.is-search-open .sprnv-mobile-search {
		display: block;
	}

	.sprnv-feed {
		flex-direction: column;
		padding-top: 100px;
	}

	.sprnv-sidebar {
		position: sticky;
		top: 0;
		z-index: 50;
		background: #fff;
		padding: 10px 0;
	}

	.sprnv-sidebar-bloc {
		display: none;
		/* on cache les blocs classiques */
	}

	.sprnv-mobile-filters {
		display: block;
		background: #fff;
		border-bottom: 1px solid var(--sprnv-border);
		padding: 10px;
		width: calc(100% - 30px);
		position: fixed;
		z-index: 1;
	}

	.sprnv-mobile-search input {
		width: 100%;
		padding: 10px;
		border: 1px solid var(--sprnv-border);
		border-radius: 8px;
		margin-top: 8px;
	}

	.sprnv-mobile-subjects {
		display: none;
		margin-top: 10px;
	}

	.sprnv-mobile-filters.is-open .sprnv-mobile-subjects {
		display: block;
	}
}

@media (max-width: 600px) {
	.forum-section .container {
		margin: 0;
		padding: 0;
	}

	.sprnv-mobile-filters {
		left: 0;
		width: 100%;
	}
}

/* =====================================================================
   Membres (vue ?page=members) + Mon espace
   ===================================================================== */

/* --- Sidebar : navigation Accueil / Membres --- */
.sprnv-sidebar-nav {
	padding: 10px;
}

.sprnv-nav-link {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 12px;
	border-radius: 10px;
	color: var(--sprnv-text);
	text-decoration: none;
	font-weight: 600;
	transition: .2s color ease-in-out;
}

.sprnv-nav-link:hover {
	color: var(--bleu-clair);
}

.sprnv-nav-link.is-active {
	color: var(--sprnv-blue);
	background: var(--sprnv-bg);
}

.sprnv-nav-link svg {
	flex: 0 0 20px;
}

/* --- En-tête liste membres --- */
.sprnv-members__intro h2 {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
	margin: 0;
	color: var(--sprnv-blue);
}

.sprnv-members__count {
	font-size: 14px;
	font-weight: 700;
	color: var(--sprnv-blue);
	border: 1px solid var(--sprnv-border);
	border-radius: 999px;
	padding: 4px 14px;
}

.sprnv-members__subtitle {
	margin: 8px 0 0;
	color: var(--sprnv-muted);
}

/* --- Grille de cartes membres (style capture) --- */
.sprnv-members-grid {
	list-style: none;
	margin: 18px 0 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
}

.sprnv-member-card {
	background: var(--sprnv-card);
	border: 1px solid var(--sprnv-border);
	box-shadow: var(--sprnv-shadow);
	border-radius: 0;
	padding: 28px 18px;
	text-align: center;
}

.sprnv-member-card__avatar {
	margin-bottom: 14px;
}

.sprnv-avatar-img,
.sprnv-member-card__avatar img {
	width: 96px;
	height: 96px;
	border-radius: 50%;
	object-fit: cover;
	display: inline-block;
}

.sprnv-member-card__name {
	font-size: 20px;
	font-weight: 700;
	color: var(--sprnv-blue);
	margin-bottom: 8px;
}

.sprnv-role-badge {
	display: inline-block;
	font-size: 13px;
	font-weight: 600;
	color: var(--sprnv-blue);
	border: 1px solid var(--sprnv-border);
	border-radius: 999px;
	padding: 3px 14px;
}

.sprnv-member-card__since {
	margin-top: 14px;
	color: var(--sprnv-muted);
	font-size: 14px;
}

.sprnv-avatar img {
	width: 100%;
	height: 100%;
	border-radius: 50%;
	object-fit: cover;
	display: block;
}

.sprnv-sidebar-me__head {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 12px;
}

.sprnv-sidebar-me__name {
	font-weight: 700;
	color: var(--sprnv-blue);
}

/* --- Mon espace : layout 2 colonnes, sidebar sticky --- */
.sprnv-espace {
	display: flex;
	gap: 24px;
	padding: 40px 0;
	align-items: flex-start;
}

.sprnv-espace__nav {
	flex: 0 0 260px;
	position: sticky;
	top: 100px;
	background: white;
	padding: 20px;
}

.sprnv-espace__content {
	flex: 1;
	min-width: 0;
}

body.espace-profil .sprnv-form label,
body.espace-profil .sprnv-form-row label {
	color: var(--bleu-profond);
}

body.espace-profil .sprnv-espace__content {
	background: var(--sprnv-card);
	border: 1px solid var(--sprnv-border);
	box-shadow: var(--sprnv-shadow);
	padding: 20px 22px;
}

.sprnv-espace__profile {
	text-align: center;
	margin-bottom: 16px;
}

.sprnv-espace__profile .sprnv-avatar-img,
.sprnv-espace__avatar img {
	width: 72px;
	height: 72px;
}

.sprnv-espace__name {
	font-weight: 700;
	color: var(--sprnv-blue);
	margin-top: 10px;
}

.sprnv-espace__email {
	color: var(--sprnv-muted);
	font-size: 13px;
}

.sprnv-espace__menu ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.sprnv-espace__link {
	display: block;
	padding: 11px 14px;
	border-radius: 10px;
	color: var(--sprnv-text);
	text-decoration: none;
	font-weight: 600;
	transition: .2s color ease-in-out;
}

.sprnv-espace__link:hover {
	color: var(--bleu-clair);
}

.sprnv-espace__link.is-active {
	background: var(--sprnv-bg);
}

.sprnv-espace__link--logout {
	color: #b91c1c;
	margin-top: 6px;
	border-top: 1px solid #edf6f9;
	border-radius: 0;
}


.sprnv-field {
	margin-bottom: 14px;
}

.sprnv-field__label {
	display: block;
	font-weight: 600;
	font-size: 14px;
	margin-bottom: 6px;
	color: var(--sprnv-text);
}

.sprnv-upload {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	cursor: pointer;
}

/* input masqué mais accessible au clavier */
.sprnv-upload__input {
	position: absolute;
	width: 1px;
	height: 1px;
	opacity: 0;
	overflow: hidden;
	clip: rect(0 0 0 0);
}

.sprnv-upload__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 16px;
	border: 1px solid var(--sprnv-border);
	border-radius: 10px;
	background: var(--sprnv-card);
	color: var(--sprnv-blue);
	font-weight: 600;
	font-size: 14px;
	transition: .15s;
}

.sprnv-upload:hover .sprnv-upload__btn {
	border-color: var(--sprnv-blue);
	background: var(--sprnv-bg);
}

.sprnv-upload__input:focus-visible+.sprnv-upload__btn {
	outline: 2px solid var(--sprnv-blue);
	outline-offset: 2px;
}

.sprnv-upload__name {
	color: var(--sprnv-muted);
	font-size: 13px;
	max-width: 220px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.sprnv-upload.has-file .sprnv-upload__name {
	color: var(--sprnv-text);
}

.sprnv-upload-preview {
	margin-top: 10px;
}

.sprnv-upload-preview img {
	max-width: 220px;
	max-height: 160px;
	border-radius: 10px;
	border: 1px solid var(--sprnv-border);
	display: block;
	object-fit: cover;
}

/* --- Edition profil : avatar --- */
.sprnv-avatar-edit {
	display: flex;
	gap: 18px;
	align-items: center;
	margin-bottom: 18px;
	margin-top: 30px;
}

.sprnv-avatar-edit__preview .sprnv-avatar-img {
	width: 96px;
	height: 96px;
}

.sprnv-avatar-edit__fields {
	flex: 1;
}

/* --- Nouvelle annonce --- */
.sprnv-new-post {
	margin-bottom: 18px;
}

.sprnv-new-post .sprnv-form label,
.sprnv-new-post .sprnv-form-row label {
	color: var(--bleu-moyen);
}

.sprnv-new-post__summary {
	cursor: pointer;
	font-weight: 700;
	color: var(--sprnv-blue);
	list-style: none;
}

.sprnv-new-post__summary::-webkit-details-marker {
	display: none;
}

.sprnv-new-post form {
	margin-top: 16px;
}

.sprnv-new-post textarea,
.sprnv-new-post select,
.sprnv-form textarea {
	width: 100%;
	border: 1px solid var(--sprnv-border);
	padding: 10px 12px;
	margin-top: 6px;
	font-size: 15px;
}

/* --- Listes compactes (mes likes / commentaires) --- */
.sprnv-mini-list {
	list-style: none;
	margin: 12px 0 0;
	padding: 0;
}

.sprnv-mini-list li {
	padding: 12px 0;
	border-bottom: 1px solid var(--sprnv-border);
}

.sprnv-mini-list li:last-child {
	border-bottom: none;
}

.sprnv-mini-list a {
	font-weight: 700;
	color: var(--sprnv-blue);
	text-decoration: none;
}

.sprnv-mini-list__excerpt {
	color: #374151;
	margin: 4px 0;
}

.sprnv-mini-list__meta {
	display: block;
	color: var(--sprnv-muted);
	font-size: 12px;
}

.sprnv-mini-list .is-pending {
	opacity: .7;
}

.my-account-not-logged {
	min-height: 500px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
}

/* --- Responsive --- */
@media (max-width: 900px) {
	.sprnv-members-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 768px) {
	.sprnv-espace {
		flex-direction: column;
		padding: 0;
	}

	.sprnv-espace__nav {
		position: static;
		flex: 1 1 auto;
		width: 100%;
	}

	body.espace-profil .sprnv-espace__content {
		width: 100%;
	}

	.sprnv-new-post__summary {
		padding-left: 20px;
	}
}

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