/**
 * Blog DEVCON7 — listing magazine + article single
 *
 * @package Devcon7_Theme
 */

/* -----------------------------------------------------------------------------
 * Variables locales
 * ----------------------------------------------------------------------------- */
body.devcon7-blog {
	--dc7-blog-night: #0a2540;
	--dc7-blog-electric: #00c6ff;
	--dc7-blog-gold: #f5a623;
	--dc7-blog-font: "Inter", system-ui, sans-serif;
	background: #0a2540;
	color: #f8fafc;
	font-family: var(--dc7-blog-font);
}

/*
 * GeneratePress (et .inside-article / .entry-content) impose souvent fond blanc + texte foncé.
 * Forcer la coque blog en thème nuit + texte clair (lisibilité).
 */
body.devcon7-blog #page,
body.devcon7-blog .site,
body.devcon7-blog .site.grid-container,
body.devcon7-blog #content,
body.devcon7-blog .site-content,
body.devcon7-blog .content-area,
body.devcon7-blog #primary,
body.devcon7-blog .inside-article,
body.devcon7-blog article.devcon7-page,
body.devcon7-blog .site-main,
body:has(article.devcon7-blog-page) #page,
body:has(article.devcon7-blog-page) .site,
body:has(article.devcon7-blog-page) .site.grid-container,
body:has(article.devcon7-blog-page) #content,
body:has(article.devcon7-blog-page) .site-content,
body:has(article.devcon7-blog-page) .content-area,
body:has(article.devcon7-blog-page) #primary,
body:has(article.devcon7-blog-page) .inside-article,
body:has(article.devcon7-blog-page) article.devcon7-page,
body:has(article.devcon7-blog-page) .site-main,
body:has(article.devcon7-blog-single) #page,
body:has(article.devcon7-blog-single) .site,
body:has(article.devcon7-blog-single) .site.grid-container,
body:has(article.devcon7-blog-single) #content,
body:has(article.devcon7-blog-single) .site-content,
body:has(article.devcon7-blog-single) .content-area,
body:has(article.devcon7-blog-single) #primary,
body:has(article.devcon7-blog-single) .inside-article,
body:has(article.devcon7-blog-single) article.devcon7-page,
body:has(article.devcon7-blog-single) .site-main {
	background-color: #0a2540 !important;
	color: #f8fafc !important;
}

body.devcon7-blog .entry-content,
body.devcon7-blog .entry-summary,
body:has(article.devcon7-blog-single) .entry-content {
	color: rgba(248, 250, 252, 0.92) !important;
}

body.devcon7-blog .entry-content p,
body.devcon7-blog .entry-content li,
body:has(article.devcon7-blog-single) .entry-content p,
body:has(article.devcon7-blog-single) .entry-content li {
	color: rgba(248, 250, 252, 0.92) !important;
}

body.devcon7-blog .inside-article a:not(.dc7-btn):not(.dc7-blog-pill),
body:has(article.devcon7-blog-page) .inside-article a:not(.dc7-btn):not(.dc7-blog-pill),
body:has(article.devcon7-blog-single) .inside-article a:not(.dc7-btn):not(.dc7-blog-pill) {
	color: #00c6ff;
}

body.devcon7-blog .inside-article a:not(.dc7-btn):not(.dc7-blog-pill):hover,
body:has(article.devcon7-blog-page) .inside-article a:not(.dc7-btn):not(.dc7-blog-pill):hover,
body:has(article.devcon7-blog-single) .inside-article a:not(.dc7-btn):not(.dc7-blog-pill):hover {
	color: #f5a623;
}

body.devcon7-blog h1,
body.devcon7-blog h2,
body.devcon7-blog h3,
body.devcon7-blog h4,
body:has(article.devcon7-blog-page) h1,
body:has(article.devcon7-blog-page) h2,
body:has(article.devcon7-blog-single) h1,
body:has(article.devcon7-blog-single) h2,
body:has(article.devcon7-blog-single) h3 {
	color: #f8fafc !important;
}

body.devcon7-blog .inside-article,
body:has(article.devcon7-blog-page) .inside-article,
body:has(article.devcon7-blog-single) .inside-article {
	padding: 0;
	margin: 0;
}

/* -----------------------------------------------------------------------------
 * Hero listing
 * ----------------------------------------------------------------------------- */
.dc7-blog-hero {
	position: relative;
	padding: clamp(3rem, 8vw, 5.5rem) 1.5rem 4rem;
	overflow: hidden;
	background: linear-gradient(165deg, rgba(10, 37, 64, 0.95), rgba(10, 37, 64, 0.75));
}

.dc7-blog-hero__hex {
	position: absolute;
	inset: 0;
	opacity: 0.12;
	background-image: url("data:image/svg+xml,%3Csvg width='28' height='49' viewBox='0 0 28 49' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M14 0l12.1 7v14L14 28 1.9 21V7L14 0z' fill='none' stroke='%2300c6ff' stroke-width='0.4'/%3E%3C/svg%3E");
	background-size: 56px 98px;
	animation: dc7-hex-drift 42s linear infinite;
	pointer-events: none;
}

@keyframes dc7-hex-drift {
	from {
		background-position: 0 0;
	}
	to {
		background-position: 112px 196px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.dc7-blog-hero__hex {
		animation: none;
	}
}

.dc7-blog-hero__inner {
	position: relative;
	z-index: 2;
	max-width: 880px;
	margin: 0 auto;
	text-align: center;
}

.dc7-blog-hero__title {
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	margin: 0 0 1rem;
	line-height: 1.08;
}

.dc7-blog-hero__word {
	display: inline-block;
	margin-right: 0.35em;
}

.dc7-blog-hero__subtitle {
	color: var(--dc7-muted);
	font-size: clamp(1rem, 2vw, 1.2rem);
	margin: 0 0 2rem;
}

.dc7-blog-search {
	display: flex;
	max-width: 440px;
	margin: 0 auto 2rem;
	padding: 0.35rem;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(0, 198, 255, 0.25);
	backdrop-filter: blur(16px);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.2);
}

.dc7-blog-search input[type="search"] {
	flex: 1;
	border: none;
	background: transparent;
	color: var(--dc7-white);
	padding: 0.65rem 1rem;
	font-family: inherit;
	font-size: 0.95rem;
	outline: none;
}

.dc7-blog-search input::placeholder {
	color: rgba(248, 250, 252, 0.45);
}

.dc7-blog-search__btn {
	border: none;
	border-radius: 999px;
	padding: 0.65rem 1.35rem;
	background: linear-gradient(135deg, var(--dc7-blog-electric), var(--dc7-blog-gold));
	color: var(--dc7-blog-night);
	font-weight: 700;
	cursor: pointer;
	font-family: inherit;
}

.dc7-blog-hero__badge {
	display: inline-flex;
	align-items: baseline;
	gap: 0.5rem;
	padding: 0.5rem 1.25rem;
	border-radius: 999px;
	background: rgba(245, 166, 35, 0.12);
	border: 1px solid rgba(245, 166, 35, 0.35);
}

.dc7-blog-hero__badge-num {
	font-size: 1.75rem;
	font-weight: 800;
	color: var(--dc7-blog-gold);
}

.dc7-blog-hero__badge-label {
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--dc7-muted);
}

/* -----------------------------------------------------------------------------
 * Filtres pills
 * ----------------------------------------------------------------------------- */
.dc7-blog-filters {
	margin-top: clamp(1.5rem, 4vw, 2.75rem);
	margin-bottom: 2rem;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
}

.dc7-blog-filters__track {
	display: flex;
	gap: 0.65rem;
	flex-wrap: nowrap;
	padding-bottom: 0.25rem;
}

.dc7-blog-pill {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	border: 1px solid rgba(0, 198, 255, 0.35);
	background: rgba(10, 37, 64, 0.5);
	color: var(--dc7-white);
	padding: 0.55rem 1.15rem;
	border-radius: 999px;
	font-size: 0.8125rem;
	font-weight: 600;
	cursor: pointer;
	font-family: inherit;
	text-decoration: none;
	transition: box-shadow 0.35s ease, transform 0.2s ease, border-color 0.2s;
}

.dc7-blog-pill:hover {
	border-color: var(--dc7-blog-electric);
	transform: translateY(-1px);
}

.dc7-blog-pill.is-active {
	background: linear-gradient(135deg, rgba(0, 198, 255, 0.35), rgba(245, 166, 35, 0.25));
	border-color: transparent;
	box-shadow: 0 0 24px rgba(0, 198, 255, 0.35), 0 0 40px rgba(245, 166, 35, 0.12);
	color: #fff;
}

/* -----------------------------------------------------------------------------
 * Layout listing + sidebar
 * ----------------------------------------------------------------------------- */
.dc7-blog-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) min(320px, 32vw);
	gap: clamp(1.5rem, 4vw, 2.5rem);
	padding: clamp(1.5rem, 3vw, 2.5rem) 1.5rem 4rem;
	max-width: 1320px;
	margin: 0 auto;
	align-items: start;
}

@media (max-width: 1024px) {
	.dc7-blog-layout {
		grid-template-columns: 1fr;
	}
}

.dc7-blog-sidebar {
	position: sticky;
	top: calc(var(--dc7-header-h, 5rem) + 1rem);
}

.dc7-blog-sidebar.is-collapsed .dc7-blog-sidebar__inner {
	display: none;
}

.dc7-blog-sidebar__toggle {
	display: none;
	width: 100%;
	margin-bottom: 0.75rem;
	padding: 0.65rem;
	border-radius: var(--dc7-radius);
	border: 1px solid rgba(0, 198, 255, 0.35);
	background: rgba(255, 255, 255, 0.05);
	color: var(--dc7-white);
	font-family: inherit;
	cursor: pointer;
}

@media (max-width: 1024px) {
	.dc7-blog-sidebar__toggle {
		display: block;
	}
}

.dc7-blog-sidebar__inner {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

.dc7-blog-sidebar__inner .dc7-blog-widget:first-of-type {
	margin-top: 0.5rem;
}

.dc7-blog-widget__title {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--dc7-blog-electric);
	margin: 0 0 1rem;
}

.dc7-blog-popular {
	list-style: none;
	margin: 0;
	padding: 0;
	counter-reset: popular;
}

.dc7-blog-popular li {
	display: flex;
	gap: 0.75rem;
	align-items: flex-start;
	margin-bottom: 1rem;
}

.dc7-blog-popular__num {
	flex-shrink: 0;
	width: 1.75rem;
	height: 1.75rem;
	border-radius: 50%;
	background: rgba(245, 166, 35, 0.2);
	color: var(--dc7-blog-gold);
	font-weight: 800;
	font-size: 0.75rem;
	display: flex;
	align-items: center;
	justify-content: center;
}

.dc7-blog-popular a {
	color: var(--dc7-white);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.9rem;
	line-height: 1.35;
}

.dc7-blog-popular a:hover {
	color: var(--dc7-blog-electric);
}

.dc7-blog-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.45rem;
	align-items: center;
}

.dc7-blog-tag {
	font-size: calc(0.7rem * var(--dc7-tag-size, 1));
	padding: 0.25rem 0.6rem;
	border-radius: 999px;
	background: rgba(0, 198, 255, 0.1);
	border: 1px solid rgba(0, 198, 255, 0.25);
	color: var(--dc7-blog-electric);
	text-decoration: none;
	font-weight: 600;
}

.dc7-blog-tag:hover {
	box-shadow: 0 0 16px rgba(0, 198, 255, 0.3);
}

.dc7-blog-newsletter__text {
	font-size: 0.875rem;
	color: var(--dc7-muted);
	margin: 0 0 1rem;
}

.dc7-blog-newsletter__form {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.dc7-blog-newsletter__form input {
	border-radius: var(--dc7-radius);
	border: 1px solid rgba(0, 198, 255, 0.3);
	background: rgba(255, 255, 255, 0.06);
	backdrop-filter: blur(10px);
	padding: 0.65rem 1rem;
	color: var(--dc7-white);
	font-family: inherit;
}

.dc7-blog-newsletter__submit {
	border: none;
	border-radius: var(--dc7-radius);
	padding: 0.65rem;
	background: linear-gradient(135deg, var(--dc7-blog-electric), rgba(245, 166, 35, 0.85));
	color: var(--dc7-blog-night);
	font-weight: 700;
	cursor: pointer;
	font-family: inherit;
}

.dc7-blog-djiz {
	padding: 1.5rem;
	border-radius: var(--dc7-radius-lg);
	background: linear-gradient(135deg, rgba(0, 198, 255, 0.15), rgba(245, 166, 35, 0.1));
	border: 1px solid rgba(245, 166, 35, 0.35);
	text-align: center;
	transition: transform 0.35s ease;
}

.dc7-blog-djiz:hover {
	transform: translateY(-4px);
}

.dc7-blog-djiz strong {
	display: block;
	font-size: 1.25rem;
	color: var(--dc7-blog-electric);
	margin-bottom: 0.5rem;
}

.dc7-blog-djiz p {
	font-size: 0.85rem;
	color: var(--dc7-muted);
	margin: 0 0 1rem;
}

.dc7-blog-djiz a {
	color: var(--dc7-blog-gold);
	font-weight: 700;
	text-decoration: none;
}

/* -----------------------------------------------------------------------------
 * Magazine grid
 * ----------------------------------------------------------------------------- */
.dc7-blog-mag {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	position: relative;
	z-index: 1;
}

.dc7-blog-mag__featured {
	width: 100%;
}

.dc7-blog-mag__secondary {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.25rem;
}

@media (max-width: 780px) {
	.dc7-blog-mag__secondary {
		grid-template-columns: 1fr;
	}
}

.dc7-blog-mag__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.25rem;
}

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

@media (max-width: 560px) {
	.dc7-blog-mag__grid {
		grid-template-columns: 1fr;
	}
}

/* -----------------------------------------------------------------------------
 * Cartes articles
 * ----------------------------------------------------------------------------- */
.dc7-card-article {
	position: relative;
	z-index: 1;
	isolation: isolate;
	border-radius: var(--dc7-radius-lg);
	overflow: hidden;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(0, 198, 255, 0.2);
}

.dc7-card-article__link {
	display: block;
	text-decoration: none;
	color: #f8fafc !important;
	height: 100%;
	position: relative;
	z-index: 3;
	cursor: pointer;
	pointer-events: auto;
	-webkit-tap-highlight-color: rgba(0, 198, 255, 0.2);
}

.dc7-card-article--featured .dc7-card-article__media {
	position: relative;
	aspect-ratio: 21 / 9;
	min-height: 280px;
	overflow: hidden;
}

.dc7-card-article--featured .dc7-card-article__img--cover {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

.dc7-card-article--featured:hover .dc7-card-article__img--cover {
	transform: scale(1.06);
}

.dc7-card-article__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 20%, rgba(10, 37, 64, 0.75) 55%, rgba(10, 37, 64, 0.95) 100%);
	pointer-events: none;
}

.dc7-card-article__badge {
	position: absolute;
	top: 1.25rem;
	left: 1.25rem;
	z-index: 2;
	padding: 0.35rem 0.85rem;
	border-radius: 999px;
	background: rgba(0, 198, 255, 0.2);
	border: 1px solid rgba(0, 198, 255, 0.45);
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.dc7-card-article__featured-bottom {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 2rem 1.75rem 1.75rem;
	z-index: 2;
	transform: translateY(0);
	transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

.dc7-card-article--featured:hover .dc7-card-article__featured-bottom {
	transform: translateY(-6px);
}

.dc7-card-article--featured .dc7-card-article__title {
	font-size: clamp(1.65rem, 3.5vw, 2.75rem);
	font-weight: 800;
	line-height: 1.1;
	margin: 0 0 0.75rem;
	letter-spacing: -0.02em;
}

.dc7-card-article__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem 1.25rem;
	font-size: 0.8125rem;
	color: rgba(248, 250, 252, 0.75);
}

.dc7-card-article--secondary .dc7-card-article__link--row {
	display: grid;
	grid-template-columns: 1fr 1.2fr;
	gap: 0;
	min-height: 200px;
}

@media (max-width: 560px) {
	.dc7-card-article--secondary .dc7-card-article__link--row {
		grid-template-columns: 1fr;
	}
}

.dc7-card-article--secondary .dc7-card-article__thumb {
	min-height: 180px;
}

.dc7-card-article--secondary .dc7-card-article__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.dc7-card-article--secondary .dc7-card-article__body {
	padding: 1.25rem 1.25rem 1.25rem 1.5rem;
	border-left: 4px solid var(--dc7-blog-electric);
	transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.dc7-card-article--secondary.dc7-blog-cat--fintech .dc7-card-article__body,
.dc7-card-article--secondary.dc7-blog-cat--digital .dc7-card-article__body {
	border-left-color: var(--dc7-blog-electric);
}

.dc7-card-article--secondary.dc7-blog-cat--ia .dc7-card-article__body {
	border-left-color: #c4b5fd;
}

.dc7-card-article--secondary.dc7-blog-cat--djizhub .dc7-card-article__body,
.dc7-card-article--secondary.dc7-blog-cat--default .dc7-card-article__body {
	border-left-color: var(--dc7-blog-gold);
}

.dc7-card-article--secondary.dc7-blog-cat--senegal .dc7-card-article__body {
	border-left-color: #34d399;
}

.dc7-card-article--secondary:hover .dc7-card-article__body {
	transform: translateY(-6px);
	box-shadow: 0 20px 48px rgba(0, 198, 255, 0.15);
}

.dc7-card-article__tag {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--dc7-blog-electric);
	margin-bottom: 0.5rem;
}

.dc7-card-article__title--sm {
	font-size: 1.25rem;
	margin: 0 0 0.5rem;
	line-height: 1.2;
}

.dc7-card-article__excerpt {
	font-size: 0.9rem;
	color: var(--dc7-muted);
	line-height: 1.55;
	margin: 0;
}

.dc7-card-article__read {
	display: inline-block;
	margin-top: 0.75rem;
	font-size: 0.85rem;
	font-weight: 700;
	color: var(--dc7-blog-gold);
}

.dc7-card-article--standard {
	min-height: 320px;
}

.dc7-card-article--standard .dc7-card-article__link--col {
	position: relative;
	padding: 1.5rem 1.25rem;
	display: flex;
	flex-direction: column;
	height: 100%;
	transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.dc7-card-article--standard:hover .dc7-card-article__link--col {
	transform: translateY(-8px);
	box-shadow: 0 24px 56px rgba(0, 198, 255, 0.12);
}

.dc7-card-article__bg-num {
	position: absolute;
	right: 0.5rem;
	top: 0.25rem;
	font-size: clamp(3.5rem, 8vw, 5rem);
	font-weight: 800;
	line-height: 1;
	color: rgba(0, 198, 255, 0.08);
	pointer-events: none;
	transition: color 0.35s ease, transform 0.35s ease;
}

.dc7-card-article--standard:hover .dc7-card-article__bg-num {
	color: rgba(0, 198, 255, 0.14);
	transform: scale(1.05);
}

.dc7-card-article__thumb--sm {
	aspect-ratio: 16 / 10;
	border-radius: var(--dc7-radius);
	overflow: hidden;
	margin-bottom: 0.75rem;
}

.dc7-card-article__thumb--sm .dc7-card-article__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.dc7-card-article__title--xs {
	font-size: 1.05rem;
	margin: 0 0 0.35rem;
	line-height: 1.25;
}

.dc7-card-article__excerpt--clamp {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.dc7-card-article__read--underline {
	position: relative;
	padding-bottom: 2px;
}

.dc7-card-article__read--underline::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 0;
	height: 2px;
	background: linear-gradient(90deg, var(--dc7-blog-electric), var(--dc7-blog-gold));
	transition: width 0.35s ease;
}

.dc7-card-article--standard:hover .dc7-card-article__read--underline::after {
	width: 100%;
}

.dc7-blog-empty {
	text-align: center;
	color: var(--dc7-muted);
	padding: 3rem 1rem;
}

/* Pagination */
.dc7-blog-pagination .page-numbers {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	list-style: none;
	margin: 2rem 0 0;
	padding: 0;
}

.dc7-blog-pagination li {
	display: inline-block;
}

.dc7-blog-pagination a,
.dc7-blog-pagination span.page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5rem;
	height: 2.5rem;
	padding: 0 0.75rem;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(0, 198, 255, 0.2);
	color: var(--dc7-white);
	text-decoration: none;
	font-size: 0.875rem;
}

.dc7-blog-pagination span.current {
	background: linear-gradient(135deg, rgba(0, 198, 255, 0.35), rgba(245, 166, 35, 0.2));
	border-color: transparent;
}

.dc7-blog-infinite {
	text-align: center;
	margin-top: 2rem;
}

.dc7-blog-infinite__btn {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.85rem 1.75rem;
	border-radius: 999px;
	border: 1px solid rgba(0, 198, 255, 0.4);
	background: rgba(10, 37, 64, 0.6);
	color: var(--dc7-white);
	font-family: inherit;
	font-weight: 600;
	cursor: pointer;
}

.dc7-blog-infinite__btn.is-loading .dc7-blog-infinite__label {
	opacity: 0.5;
}

.dc7-blog-infinite__loader {
	width: 22px;
	height: 22px;
	border: 2px solid rgba(0, 198, 255, 0.25);
	border-top-color: var(--dc7-blog-electric);
	border-radius: 50%;
	animation: dc7-spin 0.75s linear infinite;
	opacity: 0;
}

.dc7-blog-infinite__btn.is-loading .dc7-blog-infinite__loader {
	opacity: 1;
}

@keyframes dc7-spin {
	to {
		transform: rotate(360deg);
	}
}

@media (prefers-reduced-motion: reduce) {
	.dc7-blog-infinite__loader {
		animation: none;
	}
}

/* -----------------------------------------------------------------------------
 * Single article
 * ----------------------------------------------------------------------------- */
.dc7-read-progress {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 10040;
	height: 3px;
	background: rgba(10, 37, 64, 0.5);
	pointer-events: none;
}

.dc7-read-progress__bar {
	height: 100%;
	width: 0%;
	background: linear-gradient(90deg, var(--dc7-blog-electric), var(--dc7-blog-gold));
	box-shadow: 0 0 12px rgba(0, 198, 255, 0.6);
}

.dc7-read-progress__pct {
	position: fixed;
	top: 10px;
	right: 12px;
	z-index: 10041;
	font-size: 0.65rem;
	color: rgba(248, 250, 252, 0.45);
}

.dc7-single-hero {
	position: relative;
	z-index: 0;
	margin-bottom: 0;
	/*
	 * Espace net sous le masthead fixe (--dc7-header-h dans header-footer.css).
	 * Le body a déjà padding-top ; on ajoute une marge visuelle pour que le titre
	 * (bloc en bas du hero) ne remonte pas sous la barre, surtout sans image à la une.
	 */
	padding-top: clamp(2rem, 5vw, 3.25rem);
}

body.admin-bar.devcon7-blog article.devcon7-blog-single .dc7-single-hero,
body.admin-bar:has(article.devcon7-blog-single) article.devcon7-blog-single .dc7-single-hero {
	padding-top: clamp(2.5rem, 6vw, 4rem);
}

/* Ancres dans le corps (#slug-de-titre) : ne pas passer sous le header au scroll. */
article.devcon7-blog-single .dc7-single-body :where(h2, h3, h4)[id] {
	scroll-margin-top: calc(var(--dc7-header-h, 5.25rem) + env(safe-area-inset-top, 0px) + 0.75rem);
}

body.admin-bar article.devcon7-blog-single .dc7-single-body :where(h2, h3, h4)[id] {
	scroll-margin-top: calc(32px + var(--dc7-header-h, 5.25rem) + env(safe-area-inset-top, 0px) + 0.75rem);
}

@media screen and (max-width: 782px) {
	body.admin-bar article.devcon7-blog-single .dc7-single-body :where(h2, h3, h4)[id] {
		scroll-margin-top: calc(46px + var(--dc7-header-h, 5.25rem) + env(safe-area-inset-top, 0px) + 0.75rem);
	}
}

.dc7-single-hero__media {
	position: relative;
	min-height: clamp(320px, 55vh, 520px);
	overflow: hidden;
}

.dc7-single-hero__media--plain {
	/* Plus de hauteur = le titre (positionné en bas) descend dans la page. */
	min-height: clamp(280px, 46vh, 400px);
	background: radial-gradient(ellipse at 30% 20%, rgba(0, 198, 255, 0.2), transparent 55%);
}

.dc7-single-hero__img {
	width: 100%;
	height: 120%;
	object-fit: cover;
	display: block;
	transform: translateY(0);
	will-change: transform;
}

.dc7-single-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 35%, #0a2540 100%);
}

.dc7-single-hero__content {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: clamp(1.75rem, 4.5vw, 3.25rem) clamp(1.5rem, 4vw, 3rem)
		clamp(2rem, 5vw, 3.5rem);
	max-width: 900px;
	margin: 0 auto;
	z-index: 2;
}

.dc7-single-hero__floating {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-bottom: 1rem;
}

.dc7-single-hero__cat {
	padding: 0.35rem 0.9rem;
	border-radius: 999px;
	background: rgba(0, 198, 255, 0.2);
	border: 1px solid rgba(0, 198, 255, 0.45);
	color: var(--dc7-white);
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	text-decoration: none;
}

.dc7-single-hero__read {
	font-size: 0.75rem;
	color: rgba(248, 250, 252, 0.7);
	padding: 0.35rem 0.9rem;
	border-radius: 999px;
	border: 1px solid rgba(248, 250, 252, 0.2);
}

.dc7-single-hero__title {
	font-size: clamp(1.85rem, 4.5vw, 3rem);
	font-weight: 800;
	line-height: 1.1;
	margin: 0 0 1rem;
	letter-spacing: -0.02em;
}

.dc7-single-hero__byline {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	font-size: 0.9rem;
	color: var(--dc7-muted);
}

.dc7-single-hero__avatar {
	border-radius: 50%;
	border: 2px solid rgba(0, 198, 255, 0.4);
}

.dc7-single-hero__author {
	font-weight: 600;
	color: var(--dc7-white);
	display: block;
}

.dc7-single-hero__date {
	display: block;
	font-size: 0.8rem;
}

.dc7-single-wrap {
	position: relative;
	display: grid;
	grid-template-columns: 52px minmax(0, 220px) minmax(0, 720px);
	gap: clamp(1rem, 3vw, 2rem);
	max-width: 1100px;
	margin: 0 auto;
	padding: clamp(2rem, 5vw, 3.5rem) 1.5rem 4rem;
	align-items: start;
}

@media (max-width: 1100px) {
	.dc7-single-wrap {
		grid-template-columns: 52px minmax(0, 1fr);
	}
	.dc7-single-toc {
		display: none;
	}
}

@media (max-width: 600px) {
	.dc7-single-wrap {
		grid-template-columns: 1fr;
	}
}

.dc7-single-share {
	position: sticky;
	top: calc(var(--dc7-header-h, 5rem) + 2rem);
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	align-self: flex-start;
}

@media (max-width: 600px) {
	.dc7-single-share {
		flex-direction: row;
		position: relative;
		top: auto;
		justify-content: center;
		margin-bottom: 1rem;
	}
}

.dc7-single-share__btn {
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	border: 1px solid rgba(0, 198, 255, 0.35);
	background: rgba(10, 37, 64, 0.8);
	color: var(--dc7-white);
	text-decoration: none;
	font-weight: 800;
	font-size: 0.85rem;
	cursor: pointer;
	transition: transform 0.35s ease, background 0.25s ease, box-shadow 0.25s ease;
}

.dc7-single-share__btn:hover {
	transform: rotate(12deg) scale(1.05);
	background: rgba(0, 198, 255, 0.2);
	box-shadow: 0 0 20px rgba(0, 198, 255, 0.35);
}

.dc7-single-toc__inner {
	position: sticky;
	top: calc(var(--dc7-header-h, 5rem) + 1rem);
	padding: 1.25rem;
	border-radius: var(--dc7-radius);
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(0, 198, 255, 0.15);
	max-height: 70vh;
	overflow: auto;
}

.dc7-single-toc__label {
	font-size: 0.65rem;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--dc7-blog-electric);
	margin: 0 0 0.75rem;
}

.dc7-single-toc__nav a {
	display: block;
	font-size: 0.8rem;
	color: var(--dc7-muted);
	text-decoration: none;
	padding: 0.35rem 0;
	border-left: 2px solid transparent;
	padding-left: 0.65rem;
	margin-left: -2px;
}

.dc7-single-toc__nav a.is-active {
	color: var(--dc7-white);
	border-left-color: var(--dc7-blog-electric);
}

.dc7-single-toc__nav a.dc7-toc-h3 {
	padding-left: 1.15rem;
	font-size: 0.75rem;
}

.dc7-single-body {
	min-width: 0;
	font-size: 1.125rem;
	line-height: 1.85;
	color: rgba(248, 250, 252, 0.92);
}

.dc7-single-body > p:first-of-type::first-letter {
	float: left;
	font-size: 4.25rem;
	line-height: 0.9;
	padding-right: 0.55rem;
	font-weight: 800;
	color: var(--dc7-blog-gold);
}

.dc7-single-body h2 {
	position: relative;
	font-size: 1.65rem;
	margin: 2.5rem 0 1rem;
	clear: both;
}

@media (min-width: 900px) {
	.dc7-single-body h2 .dc7-sec-num {
		position: absolute;
		left: -3.5rem;
		top: 0.15rem;
		font-size: 0.75rem;
		font-weight: 800;
		color: rgba(245, 166, 35, 0.55);
		width: 2.5rem;
		text-align: right;
	}
}

.dc7-single-body h3 {
	font-size: 1.2rem;
	margin: 2rem 0 0.65rem;
	color: var(--dc7-white);
}

.dc7-single-body blockquote {
	margin: 2rem 0;
	padding: 1.25rem 1.5rem;
	border-left: 4px solid var(--dc7-blog-electric);
	background: rgba(0, 198, 255, 0.06);
	backdrop-filter: blur(8px);
	border-radius: 0 var(--dc7-radius) var(--dc7-radius) 0;
	font-style: italic;
	color: var(--dc7-muted);
}

.dc7-single-body code {
	background: rgba(10, 20, 40, 0.85);
	color: var(--dc7-blog-electric);
	padding: 0.15rem 0.45rem;
	border-radius: 6px;
	font-size: 0.9em;
}

.dc7-single-body pre {
	background: rgba(5, 15, 35, 0.9);
	border: 1px solid rgba(0, 198, 255, 0.2);
	padding: 1.25rem;
	border-radius: var(--dc7-radius);
	overflow-x: auto;
}

.dc7-single-body img {
	max-width: 100%;
	height: auto;
	border-radius: var(--dc7-radius);
	box-shadow: var(--dc7-shadow);
}

.dc7-single-body figcaption {
	font-size: 0.85rem;
	color: var(--dc7-muted);
	text-align: center;
	margin-top: 0.5rem;
}

/* Callouts (à utiliser dans l’éditeur : div.dc7-callout.dc7-callout--info) */
.dc7-callout {
	display: flex;
	gap: 1rem;
	padding: 1.25rem 1.5rem;
	border-radius: var(--dc7-radius);
	margin: 2rem 0;
	border: 1px solid rgba(255, 255, 255, 0.08);
	background: rgba(255, 255, 255, 0.04);
}

.dc7-callout::before {
	flex-shrink: 0;
	width: 1.75rem;
	height: 1.75rem;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 800;
	font-size: 0.9rem;
}

.dc7-callout--info::before {
	content: "i";
	background: rgba(0, 198, 255, 0.2);
	color: var(--dc7-blog-electric);
}

.dc7-callout--warning::before {
	content: "!";
	background: rgba(245, 166, 35, 0.2);
	color: var(--dc7-blog-gold);
}

.dc7-callout--tip::before {
	content: "★";
	background: rgba(0, 198, 255, 0.15);
	color: var(--dc7-blog-gold);
}

.dc7-single-tags {
	display: block;
	clear: both;
	max-width: 900px;
	margin: clamp(3.25rem, 7vw, 5.5rem) auto 2rem;
	padding: clamp(2rem, 4vw, 2.75rem) 1.5rem 0;
	border-top: 1px solid rgba(0, 198, 255, 0.2);
}

.dc7-single-tags__label {
	display: inline-block;
	margin-right: 0.5rem;
	margin-bottom: 0.75rem;
	color: rgba(248, 250, 252, 0.75);
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.dc7-single-tags a {
	display: inline-block;
	margin: 0.25rem 0.5rem 0.25rem 0;
	padding: 0.35rem 0.85rem;
	border-radius: 999px;
	border: 1px solid rgba(0, 198, 255, 0.3);
	color: var(--dc7-blog-electric);
	text-decoration: none;
	font-size: 0.8rem;
	transition: box-shadow 0.25s ease;
}

.dc7-single-tags a:hover {
	box-shadow: 0 0 14px rgba(0, 198, 255, 0.35);
}

.dc7-single-author {
	display: flex;
	gap: 1.25rem;
	max-width: 900px;
	margin: 0 auto 3rem;
	padding: 1.75rem 1.5rem;
	border-radius: var(--dc7-radius-lg);
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(245, 166, 35, 0.2);
}

.dc7-single-author__avatar {
	border-radius: 50%;
	flex-shrink: 0;
	border: 2px solid rgba(245, 166, 35, 0.4);
}

.dc7-single-author__name {
	display: block;
	font-size: 1.1rem;
	margin-bottom: 0.35rem;
}

.dc7-single-author__bio {
	margin: 0 0 1rem;
	color: var(--dc7-muted);
	font-size: 0.95rem;
}

.dc7-single-related {
	max-width: 1100px;
	margin: 0 auto 3rem;
	padding: 0 1.5rem;
}

.dc7-single-related__title {
	font-size: 1.35rem;
	margin-bottom: 1.25rem;
}

.dc7-single-related__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
}

@media (max-width: 900px) {
	.dc7-single-related__grid {
		grid-template-columns: 1fr;
	}
}

.dc7-single-related__card {
	display: flex;
	gap: 1rem;
	align-items: center;
	text-decoration: none;
	color: inherit;
	padding: 1rem;
	border-radius: var(--dc7-radius);
	border: 1px solid rgba(0, 198, 255, 0.15);
	background: rgba(255, 255, 255, 0.02);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.dc7-single-related__card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 40px rgba(0, 198, 255, 0.1);
}

.dc7-single-related__thumb {
	flex-shrink: 0;
	width: 100px;
	height: 72px;
	border-radius: 8px;
	overflow: hidden;
}

.dc7-single-related__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.dc7-single-related__body {
	position: relative;
	min-width: 0;
}

.dc7-single-related__num {
	position: absolute;
	right: 0;
	top: 0;
	font-size: 2rem;
	font-weight: 800;
	color: rgba(0, 198, 255, 0.1);
	line-height: 1;
}

.dc7-single-related__body h3 {
	font-size: 1rem;
	margin: 0;
	line-height: 1.35;
}

/* -----------------------------------------------------------------------------
 * Commentaires
 * ----------------------------------------------------------------------------- */
.dc7-comments {
	max-width: 900px;
	margin: 0 auto 4rem;
	padding: 0 1.5rem;
}

.dc7-comments__title {
	font-size: 1.35rem;
	margin-bottom: 1.5rem;
}

.dc7-comments__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.dc7-comment {
	margin-bottom: 1.5rem;
}

.dc7-comment__inner {
	display: flex;
	gap: 1rem;
	padding: 1.25rem;
	border-radius: var(--dc7-radius);
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(0, 198, 255, 0.1);
}

.dc7-comment__avatar,
.dc7-comment__avatar--initial {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	object-fit: cover;
}

.dc7-comment__avatar--initial {
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, rgba(0, 198, 255, 0.35), rgba(245, 166, 35, 0.35));
	color: var(--dc7-white);
	font-weight: 800;
}

.dc7-comment__meta {
	font-size: 0.8rem;
	margin-bottom: 0.35rem;
	color: var(--dc7-muted);
}

.dc7-comment__author a {
	color: var(--dc7-white);
	font-weight: 700;
	text-decoration: none;
}

.dc7-comment__content {
	font-size: 0.95rem;
	line-height: 1.65;
}

.dc7-comment-form {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	margin-top: 2rem;
	padding: 1.5rem;
	border-radius: var(--dc7-radius-lg);
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(0, 198, 255, 0.18);
	backdrop-filter: blur(12px);
}

.dc7-comment-form__input,
.dc7-comment-form__textarea {
	width: 100%;
	border-radius: var(--dc7-radius);
	border: 1px solid rgba(0, 198, 255, 0.25);
	background: rgba(10, 37, 64, 0.5);
	color: var(--dc7-white);
	padding: 0.65rem 1rem;
	font-family: inherit;
}

.dc7-comment-form__textarea {
	min-height: 140px;
	resize: vertical;
}

.dc7-comment-form__submit {
	align-self: flex-start;
	padding: 0.65rem 1.5rem;
	border: none;
	border-radius: 999px;
	background: linear-gradient(135deg, var(--dc7-blog-electric), rgba(245, 166, 35, 0.85));
	color: var(--dc7-blog-night);
	font-weight: 700;
	cursor: pointer;
	font-family: inherit;
}

/* Toast */
.dc7-toast {
	position: fixed;
	bottom: 1.5rem;
	left: 50%;
	transform: translateX(-50%) translateY(120%);
	z-index: 100090;
	padding: 0.65rem 1.25rem;
	border-radius: 999px;
	background: rgba(10, 37, 64, 0.95);
	border: 1px solid var(--dc7-blog-electric);
	color: var(--dc7-white);
	font-size: 0.875rem;
	transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

.dc7-toast.is-visible {
	transform: translateX(-50%) translateY(0);
}

@media (prefers-reduced-motion: reduce) {
	.dc7-card-article--featured .dc7-card-article__img--cover,
	.dc7-card-article--secondary:hover .dc7-card-article__body,
	.dc7-card-article--standard:hover .dc7-card-article__link--col {
		transition: none;
		transform: none;
	}
}
