/*
Theme Name: DEVCON7
Theme URI: https://devcon7.sn
Description: Child theme GeneratePress pour DEVCON7 — Fintech & solutions digitales, Sénégal. Identité Afrique digitale, animations GSAP.
Author: DEVCON7
Template: generatepress
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.9
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: devcon7-theme
*/

/* -----------------------------------------------------------------------------
 * Variables d’identité — DEVCON7 (Fintech B2B Afrique)
 * ----------------------------------------------------------------------------- */
:root {
	--dc7-night: #0a2540;
	--dc7-electric: #00c6ff;
	--dc7-gold: #f5a623;
	--dc7-night-rgb: 10, 37, 64;
	--dc7-electric-rgb: 0, 198, 255;
	--dc7-gold-rgb: 245, 166, 35;
	--dc7-white: #f8fafc;
	--dc7-muted: #94a3b8;
	--dc7-font-heading: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
	--dc7-font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
	--dc7-radius: 12px;
	--dc7-radius-lg: 20px;
	--dc7-shadow: 0 24px 48px rgba(var(--dc7-night-rgb), 0.18);
	--dc7-transition: 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Typographie globale du child */
body.devcon7-landing,
body.devcon7-landing button,
body.devcon7-landing input,
body.devcon7-landing select,
body.devcon7-landing textarea {
	font-family: var(--dc7-font-body);
	font-weight: 400;
}

body.devcon7-landing h1,
body.devcon7-landing h2,
body.devcon7-landing h3,
body.devcon7-landing h4,
body.devcon7-landing .dc7-heading {
	font-family: var(--dc7-font-heading);
	font-weight: 700;
	letter-spacing: -0.02em;
}

/* Pleine largeur : #page est un .grid-container GeneratePress (max-width ~1200px) */
body.devcon7-landing #page.grid-container,
body.devcon7-landing #page.site.grid-container {
	max-width: 100% !important;
	width: 100%;
	margin-left: 0;
	margin-right: 0;
	padding-left: 0;
	padding-right: 0;
}

body.devcon7-landing.full-width-content .container.grid-container {
	max-width: 100%;
	width: 100%;
	padding-left: 0;
	padding-right: 0;
}

/* Flexbox GP : forcer la zone de contenu sur toute la ligne */
body.devcon7-landing .site-content {
	width: 100%;
	max-width: 100%;
	flex-wrap: nowrap;
}

body.devcon7-landing .site-content .content-area {
	width: 100% !important;
	max-width: 100% !important;
	flex: 1 1 100%;
	min-width: 0;
}

body.devcon7-landing #primary.content-area {
	width: 100% !important;
	max-width: 100% !important;
}

body.devcon7-landing .site-main {
	width: 100%;
	max-width: 100%;
}

body.devcon7-landing .inside-article {
	padding: 0;
	margin: 0;
}

body.devcon7-landing .devcon7-page {
	background: var(--dc7-night);
	overflow-x: hidden;
}

/*
 * Pleine largeur desktop — ne dépend pas de body.devcon7-landing (détection PHP parfois absente).
 * Le CSS dynamique GP impose ~70 % sur .content-area au-dessus de 768px ; :has() corrige après chargement du DOM.
 * Les pages sans article.devcon7-page (ex. Sample Page) restent inchangées.
 */
body:has(article.devcon7-page) #page.site.grid-container,
body:has(article.devcon7-page) #page.grid-container {
	max-width: 100% !important;
	width: 100%;
	margin-left: 0;
	margin-right: 0;
	padding-left: 0;
	padding-right: 0;
}

body:has(article.devcon7-page) .site-content {
	width: 100%;
	max-width: 100%;
}

body:has(article.devcon7-page) .site-content .content-area,
body:has(article.devcon7-page) #primary.content-area {
	width: 100% !important;
	max-width: 100% !important;
	flex: 1 1 100% !important;
	min-width: 0 !important;
}

body:has(article.devcon7-page) .site-main {
	width: 100%;
	max-width: 100%;
}

body:has(article.devcon7-page).separate-containers .site-main {
	margin-left: 0 !important;
	margin-right: 0 !important;
}

/* -----------------------------------------------------------------------------
 * Motif géométrique inspiré textiles ouest-africains (subtil)
 * ----------------------------------------------------------------------------- */
.dc7-pattern {
	background-color: var(--dc7-night);
	background-image:
		repeating-linear-gradient(
			-45deg,
			transparent,
			transparent 8px,
			rgba(var(--dc7-gold-rgb), 0.04) 8px,
			rgba(var(--dc7-gold-rgb), 0.04) 9px
		),
		radial-gradient(ellipse 80% 50% at 50% -20%, rgba(var(--dc7-electric-rgb), 0.15), transparent 55%);
}

/* -----------------------------------------------------------------------------
 * Utilitaires animations (état initial géré par GSAP)
 * ----------------------------------------------------------------------------- */
.dc7-reveal {
	will-change: transform, opacity;
}

.dc7-reveal-prep {
	opacity: 0;
	transform: translateY(36px);
}

/* -----------------------------------------------------------------------------
 * Hero
 * ----------------------------------------------------------------------------- */
.dc7-hero {
	position: relative;
	min-height: 92vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 6rem 1.5rem 5rem;
	overflow: hidden;
}

/*
 * Header DEVCON7 déjà fixe + body avec padding-top de compensation :
 * enlever le gros padding-top du hero pour éviter une double bande vide.
 */
body.dc7-fixed-masthead .dc7-hero {
	padding: clamp(1rem, 3vw, 1.75rem) 1.5rem 5rem;
}

body.dc7-fixed-masthead .dc7-hero--compact {
	padding: clamp(1rem, 2.5vw, 1.5rem) 1.5rem 3rem;
}

.dc7-hero__canvas {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
	z-index: 0;
}

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

.dc7-hero__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.35rem 1rem;
	border-radius: 999px;
	background: rgba(var(--dc7-electric-rgb), 0.12);
	border: 1px solid rgba(var(--dc7-electric-rgb), 0.35);
	color: var(--dc7-electric);
	font-size: 0.8125rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 1.5rem;
}

.dc7-hero__badge-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--dc7-gold);
	box-shadow: 0 0 12px var(--dc7-gold);
}

.dc7-hero__title {
	font-size: clamp(2.25rem, 5vw, 3.75rem);
	line-height: 1.08;
	color: var(--dc7-white);
	margin: 0 0 1rem;
}

.dc7-hero__title .dc7-line {
	display: block;
}

.dc7-hero__title-accent {
	background: linear-gradient(135deg, var(--dc7-electric) 0%, var(--dc7-gold) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

.dc7-hero__subtitle {
	font-size: clamp(1rem, 2.2vw, 1.25rem);
	color: var(--dc7-muted);
	max-width: 36rem;
	margin: 0 auto 2rem;
	line-height: 1.65;
}

.dc7-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	justify-content: center;
	align-items: center;
}

.dc7-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.95rem 1.75rem;
	border-radius: var(--dc7-radius);
	font-weight: 700;
	font-size: 0.9375rem;
	text-decoration: none;
	border: 2px solid transparent;
	transition: transform var(--dc7-transition), box-shadow var(--dc7-transition);
	cursor: pointer;
}

.dc7-btn:focus {
	outline: 2px solid var(--dc7-electric);
	outline-offset: 3px;
}

.dc7-btn--primary {
	background: linear-gradient(135deg, var(--dc7-electric), #0099cc);
	color: var(--dc7-night);
	box-shadow: 0 8px 32px rgba(var(--dc7-electric-rgb), 0.35);
}

.dc7-btn--primary:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 40px rgba(var(--dc7-electric-rgb), 0.45);
	color: var(--dc7-night);
}

.dc7-btn--ghost {
	background: transparent;
	border-color: rgba(var(--dc7-electric-rgb), 0.5);
	color: var(--dc7-electric);
}

.dc7-btn--ghost:hover {
	background: rgba(var(--dc7-electric-rgb), 0.1);
	color: var(--dc7-electric);
}

.dc7-btn--gold {
	background: var(--dc7-gold);
	color: var(--dc7-night);
}

.dc7-btn--gold:hover {
	filter: brightness(1.08);
	transform: translateY(-2px);
	color: var(--dc7-night);
}

/* -----------------------------------------------------------------------------
 * Section shell
 * ----------------------------------------------------------------------------- */
.dc7-section {
	padding: 4.5rem 1.5rem;
	position: relative;
}

.dc7-section--alt {
	background: linear-gradient(180deg, rgba(15, 45, 75, 0.6) 0%, var(--dc7-night) 100%);
}

.dc7-wrap {
	max-width: 1140px;
	margin: 0 auto;
}

.dc7-section__head {
	text-align: center;
	max-width: 640px;
	margin: 0 auto 3rem;
}

.dc7-kicker {
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--dc7-electric);
	margin-bottom: 0.75rem;
}

.dc7-section__title {
	font-size: clamp(1.75rem, 3vw, 2.25rem);
	color: var(--dc7-white);
	margin: 0 0 0.75rem;
}

.dc7-section__lead {
	color: var(--dc7-muted);
	font-size: 1.0625rem;
	line-height: 1.65;
	margin: 0;
}

/* DJIZHUB : marge titre → carte plus serrée (évite le « trou » visuel) */
.dc7-section--djiz .dc7-section__head {
	margin-bottom: 1.5rem;
}

/* -----------------------------------------------------------------------------
 * Chiffres clés
 * ----------------------------------------------------------------------------- */
.dc7-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
}

@media (max-width: 768px) {
	.dc7-stats {
		grid-template-columns: 1fr;
	}
}

.dc7-stat {
	text-align: center;
	padding: 2rem 1.25rem;
	border-radius: var(--dc7-radius-lg);
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(var(--dc7-electric-rgb), 0.15);
	backdrop-filter: blur(8px);
}

.dc7-stat__value {
	font-size: clamp(2.5rem, 4vw, 3.25rem);
	font-weight: 700;
	color: var(--dc7-electric);
	line-height: 1;
	margin-bottom: 0.35rem;
}

.dc7-stat__suffix {
	font-size: 1.75rem;
	color: var(--dc7-gold);
	vertical-align: super;
	margin-left: 2px;
}

.dc7-stat__label {
	color: var(--dc7-muted);
	font-size: 0.9375rem;
}

/* -----------------------------------------------------------------------------
 * Bloc DJIZHUB highlight
 * ----------------------------------------------------------------------------- */
.dc7-djiz {
	border-radius: var(--dc7-radius-lg);
	padding: 2.5rem 2rem;
	position: relative;
	overflow: hidden;
	background:
		linear-gradient(135deg, rgba(var(--dc7-electric-rgb), 0.12) 0%, rgba(var(--dc7-gold-rgb), 0.08) 100%),
		var(--dc7-night);
	border: 1px solid rgba(var(--dc7-gold-rgb), 0.35);
	box-shadow: var(--dc7-shadow);
}

.dc7-djiz::before {
	content: "";
	position: absolute;
	top: -40%;
	right: -20%;
	width: 55%;
	height: 120%;
	background: radial-gradient(circle, rgba(var(--dc7-electric-rgb), 0.2) 0%, transparent 70%);
	pointer-events: none;
}

.dc7-djiz__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2rem;
	align-items: center;
	position: relative;
	z-index: 1;
}

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

.dc7-djiz__logo {
	font-size: clamp(1.75rem, 3vw, 2.25rem);
	font-weight: 700;
	color: var(--dc7-white);
	margin: 0 0 1rem;
}

.dc7-djiz__logo span {
	color: var(--dc7-gold);
}

.dc7-djiz__text {
	color: var(--dc7-muted);
	line-height: 1.7;
	margin: 0 0 1.5rem;
}

.dc7-djiz__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.dc7-tag {
	padding: 0.35rem 0.85rem;
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: 600;
	background: rgba(var(--dc7-night-rgb), 0.6);
	border: 1px solid rgba(var(--dc7-electric-rgb), 0.3);
	color: var(--dc7-electric);
}

.dc7-djiz__visual {
	min-height: 220px;
	border-radius: var(--dc7-radius);
	background:
		repeating-linear-gradient(
			90deg,
			transparent,
			transparent 12px,
			rgba(var(--dc7-gold-rgb), 0.08) 12px,
			rgba(var(--dc7-gold-rgb), 0.08) 13px
		),
		linear-gradient(160deg, rgba(var(--dc7-electric-rgb), 0.15), transparent);
	display: flex;
	align-items: center;
	justify-content: center;
}

.dc7-djiz__visual-inner {
	text-align: center;
	padding: 1.5rem;
}

.dc7-djiz__visual-inner svg {
	width: 100px;
	height: auto;
	opacity: 0.9;
}

/* -----------------------------------------------------------------------------
 * Cartes services
 * ----------------------------------------------------------------------------- */
.dc7-services {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.5rem;
}

.dc7-card {
	border-radius: var(--dc7-radius-lg);
	padding: 1.75rem 1.5rem;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.08);
	transition: border-color var(--dc7-transition), background var(--dc7-transition);
}

.dc7-card:hover {
	border-color: rgba(var(--dc7-electric-rgb), 0.4);
	background: rgba(255, 255, 255, 0.06);
}

.dc7-card__icon {
	width: 52px;
	height: 52px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.25rem;
	background: linear-gradient(145deg, rgba(var(--dc7-electric-rgb), 0.25), rgba(var(--dc7-gold-rgb), 0.15));
	color: var(--dc7-electric);
}

.dc7-card__icon svg {
	width: 28px;
	height: 28px;
}

.dc7-card__title {
	font-size: 1.125rem;
	color: var(--dc7-white);
	margin: 0 0 0.65rem;
}

.dc7-card__text {
	color: var(--dc7-muted);
	font-size: 0.9375rem;
	line-height: 1.6;
	margin: 0;
}

.dc7-card__more {
	margin: 1rem 0 0;
	font-size: 0.875rem;
	font-weight: 600;
}

.dc7-link-forward {
	color: var(--dc7-electric);
	text-decoration: none;
	border-bottom: 1px solid rgba(var(--dc7-electric-rgb), 0.35);
	transition: color var(--dc7-transition), border-color var(--dc7-transition);
}

.dc7-link-forward:hover,
.dc7-link-forward:focus-visible {
	color: var(--dc7-gold);
	border-bottom-color: rgba(var(--dc7-gold-rgb), 0.55);
}

.dc7-svc-intro {
	max-width: 720px;
	margin: 0 auto 2.5rem;
	text-align: center;
	color: var(--dc7-muted);
	line-height: 1.75;
	font-size: 1.02rem;
}

.dc7-svc-intro p {
	margin: 0 0 1rem;
}

.dc7-svc-intro p:last-child {
	margin-bottom: 0;
}

.dc7-svc-block__more {
	margin: 1rem 0 0;
	font-size: 0.9375rem;
}

.dc7-breadcrumb {
	max-width: 1140px;
	margin: 0 auto;
	padding: 1rem 1.5rem 0;
	font-size: 0.8125rem;
	color: var(--dc7-muted);
}

.dc7-breadcrumb a {
	color: var(--dc7-electric);
	text-decoration: none;
}

.dc7-breadcrumb a:hover {
	text-decoration: underline;
}

.dc7-breadcrumb__sep {
	margin: 0 0.35rem;
	opacity: 0.45;
}

.dc7-breadcrumb__current {
	color: rgba(248, 250, 252, 0.75);
}

.dc7-wrap--readable {
	max-width: 720px;
}

.dc7-svc-detail-prose {
	color: rgba(248, 250, 252, 0.92);
	line-height: 1.75;
	font-size: 1.0625rem;
}

.dc7-svc-detail-prose > p {
	margin: 0 0 1.15rem;
}

.dc7-svc-detail-prose h2 {
	font-size: 1.35rem;
	color: var(--dc7-white);
	margin: 2rem 0 0.75rem;
}

.dc7-svc-detail-prose h2:first-child {
	margin-top: 0;
}

.dc7-svc-detail-prose a {
	color: var(--dc7-electric);
}

.dc7-section--svc-related {
	padding-top: 2rem;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.dc7-section__title--left,
.dc7-section__lead--left {
	text-align: left;
	margin-left: 0;
	margin-right: 0;
	max-width: none;
}

.dc7-svc-related {
	list-style: none;
	margin: 1.5rem 0 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 0.65rem 1.25rem;
}

.dc7-svc-related__link {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	color: var(--dc7-white);
	text-decoration: none;
	padding: 0.5rem 0;
	font-weight: 600;
	font-size: 0.9375rem;
	transition: color var(--dc7-transition);
}

.dc7-svc-related__link:hover {
	color: var(--dc7-electric);
}

.dc7-svc-related__link--hub {
	color: var(--dc7-gold);
}

/* -----------------------------------------------------------------------------
 * Dirigeants — grille bento, halos, orbites
 * ----------------------------------------------------------------------------- */
.dc7-section--leadership {
	padding: 5rem 1.5rem 4.5rem;
	overflow: hidden;
	background:
		radial-gradient(ellipse 90% 60% at 10% 20%, rgba(var(--dc7-electric-rgb), 0.14), transparent 50%),
		radial-gradient(ellipse 70% 50% at 95% 80%, rgba(var(--dc7-gold-rgb), 0.1), transparent 45%),
		linear-gradient(180deg, rgba(12, 42, 72, 0.95) 0%, var(--dc7-night) 100%);
}

.dc7-section--leadership .dc7-section__head {
	margin-bottom: 2.75rem;
}

.dc7-leadership__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 1.35rem;
	perspective: 1100px;
	position: relative;
}

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

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

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

.dc7-leader {
	position: relative;
	border-radius: var(--dc7-radius-lg);
	padding: 1.75rem 1.5rem 2rem;
	background: rgba(255, 255, 255, 0.035);
	border: 1px solid rgba(255, 255, 255, 0.1);
	box-shadow: 0 20px 48px rgba(0, 0, 0, 0.25);
	overflow: hidden;
	transform-style: preserve-3d;
	transition:
		transform 0.5s cubic-bezier(0.22, 1, 0.36, 1),
		border-color 0.45s ease,
		box-shadow 0.45s ease;
}

.dc7-leader:hover {
	transform: translateY(-8px) scale(1.02);
	border-color: rgba(var(--dc7-electric-rgb), 0.45);
	box-shadow:
		0 28px 56px rgba(0, 0, 0, 0.35),
		0 0 0 1px rgba(var(--dc7-electric-rgb), 0.15),
		0 0 48px rgba(var(--dc7-electric-rgb), 0.12);
}

.dc7-leader--ceo:hover {
	border-color: rgba(var(--dc7-gold-rgb), 0.5);
	box-shadow:
		0 28px 56px rgba(0, 0, 0, 0.35),
		0 0 40px rgba(var(--dc7-gold-rgb), 0.14);
}

.dc7-leader--design:hover {
	border-color: rgba(168, 85, 247, 0.45);
	box-shadow:
		0 28px 56px rgba(0, 0, 0, 0.35),
		0 0 44px rgba(168, 85, 247, 0.12);
}

.dc7-leader__orbit {
	position: absolute;
	inset: -35%;
	border-radius: 50%;
	border: 1px dashed rgba(var(--dc7-electric-rgb), 0.18);
	pointer-events: none;
	animation: dc7-leader-orbit-spin 22s linear infinite;
}

.dc7-leader--ceo .dc7-leader__orbit {
	border-color: rgba(var(--dc7-gold-rgb), 0.22);
	animation-duration: 28s;
}

.dc7-leader--design .dc7-leader__orbit {
	border-color: rgba(192, 132, 252, 0.2);
	animation-duration: 26s;
	animation-direction: reverse;
}

.dc7-leader--sales .dc7-leader__orbit {
	animation-duration: 20s;
}

.dc7-leader__glow {
	position: absolute;
	width: 140px;
	height: 140px;
	border-radius: 50%;
	filter: blur(48px);
	opacity: 0.55;
	pointer-events: none;
	top: -20px;
	right: -30px;
	background: radial-gradient(circle, rgba(var(--dc7-electric-rgb), 0.5) 0%, transparent 70%);
}

.dc7-leader--ceo .dc7-leader__glow {
	background: radial-gradient(circle, rgba(var(--dc7-gold-rgb), 0.45) 0%, transparent 70%);
	top: 50%;
	left: -40px;
	right: auto;
	transform: translateY(-50%);
}

.dc7-leader--design .dc7-leader__glow {
	background: radial-gradient(circle, rgba(192, 132, 252, 0.4) 0%, transparent 70%);
	bottom: -30px;
	top: auto;
	right: 20%;
}

.dc7-leader--sales .dc7-leader__glow {
	background: radial-gradient(circle, rgba(34, 211, 238, 0.35) 0%, transparent 70%);
}

.dc7-leader__inner {
	position: relative;
	z-index: 1;
}

.dc7-leader__avatar {
	width: 76px;
	height: 76px;
	border-radius: 22px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.15rem;
	background: linear-gradient(145deg, rgba(var(--dc7-electric-rgb), 0.35), rgba(var(--dc7-night-rgb), 0.9));
	border: 1px solid rgba(var(--dc7-electric-rgb), 0.45);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
	will-change: transform;
	overflow: hidden;
	flex-shrink: 0;
}

.dc7-leader__avatar--photo {
	padding: 0;
	background: rgba(var(--dc7-night-rgb), 0.5);
}

.dc7-leader__photo {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center top;
	display: block;
}

.dc7-leader--ceo .dc7-leader__avatar {
	background: linear-gradient(145deg, rgba(var(--dc7-gold-rgb), 0.4), rgba(var(--dc7-night-rgb), 0.95));
	border-color: rgba(var(--dc7-gold-rgb), 0.5);
}

.dc7-leader--design .dc7-leader__avatar {
	background: linear-gradient(145deg, rgba(168, 85, 247, 0.35), rgba(var(--dc7-night-rgb), 0.92));
	border-color: rgba(192, 132, 252, 0.45);
}

.dc7-leader--sales .dc7-leader__avatar {
	background: linear-gradient(145deg, rgba(34, 211, 238, 0.3), rgba(var(--dc7-night-rgb), 0.92));
	border-color: rgba(34, 211, 238, 0.4);
}

.dc7-leader__initials {
	font-size: 1.35rem;
	font-weight: 800;
	letter-spacing: 0.04em;
	color: var(--dc7-white);
}

.dc7-leader__role {
	font-size: 0.6875rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--dc7-electric);
	margin: 0 0 0.5rem;
}

.dc7-leader--ceo .dc7-leader__role {
	color: var(--dc7-gold);
}

.dc7-leader--design .dc7-leader__role {
	color: #d8b4fe;
}

.dc7-leader--sales .dc7-leader__role {
	color: #67e8f9;
}

.dc7-leader__name {
	font-size: 1.25rem;
	color: var(--dc7-white);
	margin: 0 0 0.5rem;
	letter-spacing: -0.02em;
}

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

.dc7-leader__line {
	height: 3px;
	margin-top: 1.15rem;
	border-radius: 2px;
	transform: scaleX(0.35);
	transform-origin: left center;
	background: linear-gradient(90deg, var(--dc7-electric), transparent);
	transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

.dc7-leader--ceo .dc7-leader__line {
	background: linear-gradient(90deg, var(--dc7-gold), transparent);
}

.dc7-leader--design .dc7-leader__line {
	background: linear-gradient(90deg, #c084fc, transparent);
}

.dc7-leader--sales .dc7-leader__line {
	background: linear-gradient(90deg, #22d3ee, transparent);
}

.dc7-leader:hover .dc7-leader__line {
	transform: scaleX(1);
}

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

	.dc7-leader:hover {
		transform: none;
	}
}

/* -----------------------------------------------------------------------------
 * Bande confiance
 * ----------------------------------------------------------------------------- */
.dc7-trust {
	background: rgba(0, 0, 0, 0.2);
	border-top: 1px solid rgba(255, 255, 255, 0.06);
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.dc7-trust__label {
	text-align: center;
	font-size: 0.6875rem;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: var(--dc7-muted);
	margin-bottom: 1.75rem;
}

.dc7-trust__logos {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 2rem 3rem;
}

.dc7-trust__item {
	font-weight: 700;
	font-size: 1.125rem;
	color: rgba(255, 255, 255, 0.35);
	white-space: nowrap;
}

/* -----------------------------------------------------------------------------
 * CTA final
 * ----------------------------------------------------------------------------- */
.dc7-cta-final {
	text-align: center;
	padding: 5rem 1.5rem;
	background: radial-gradient(ellipse 100% 80% at 50% 100%, rgba(var(--dc7-electric-rgb), 0.2), transparent 55%),
		var(--dc7-night);
}

.dc7-cta-final h2 {
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	color: var(--dc7-white);
	margin: 0 0 1rem;
}

.dc7-cta-final p {
	color: var(--dc7-muted);
	max-width: 480px;
	margin: 0 auto 1.75rem;
	line-height: 1.65;
}

/* -----------------------------------------------------------------------------
 * Page Services — sections détaillées
 * ----------------------------------------------------------------------------- */
.dc7-svc-block {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 1.75rem 2rem;
	align-items: start;
	padding: 2.5rem 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.dc7-svc-block:last-of-type {
	border-bottom: 0;
}

@media (max-width: 640px) {
	.dc7-svc-block {
		grid-template-columns: 1fr;
	}
}

.dc7-svc-block__icon {
	width: 64px;
	height: 64px;
	border-radius: 16px;
	background: rgba(var(--dc7-electric-rgb), 0.15);
	border: 1px solid rgba(var(--dc7-electric-rgb), 0.35);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--dc7-electric);
}

.dc7-svc-block__icon svg {
	width: 32px;
	height: 32px;
}

.dc7-svc-block h3 {
	color: var(--dc7-white);
	margin: 0 0 0.75rem;
	font-size: 1.35rem;
}

.dc7-svc-block p {
	color: var(--dc7-muted);
	line-height: 1.7;
	margin: 0;
}

.dc7-premium {
	border-radius: var(--dc7-radius-lg);
	padding: 2.5rem 2rem;
	margin: 2rem 0;
	border: 2px solid;
	position: relative;
	overflow: hidden;
}

.dc7-premium--pay {
	background: linear-gradient(145deg, rgba(var(--dc7-electric-rgb), 0.12), rgba(var(--dc7-night-rgb), 0.9));
	border-color: rgba(var(--dc7-electric-rgb), 0.45);
}

.dc7-premium--hub {
	background: linear-gradient(145deg, rgba(var(--dc7-gold-rgb), 0.15), rgba(var(--dc7-night-rgb), 0.95));
	border-color: rgba(var(--dc7-gold-rgb), 0.5);
}

.dc7-premium__ribbon {
	display: inline-block;
	font-size: 0.6875rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	padding: 0.35rem 0.85rem;
	border-radius: 6px;
	margin-bottom: 1rem;
}

.dc7-premium--pay .dc7-premium__ribbon {
	background: var(--dc7-electric);
	color: var(--dc7-night);
}

.dc7-premium--hub .dc7-premium__ribbon {
	background: var(--dc7-gold);
	color: var(--dc7-night);
}

.dc7-premium h3 {
	margin-top: 0;
	color: var(--dc7-white);
}

.dc7-premium p {
	color: var(--dc7-muted);
	line-height: 1.7;
}

/* -----------------------------------------------------------------------------
 * Contact
 * ----------------------------------------------------------------------------- */
.dc7-contact-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2.5rem;
	align-items: start;
}

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

.dc7-form label {
	display: block;
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--dc7-muted);
	margin-bottom: 0.4rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.dc7-form input[type="text"],
.dc7-form input[type="email"],
.dc7-form input[type="tel"],
.dc7-form textarea {
	width: 100%;
	padding: 0.85rem 1rem;
	border-radius: var(--dc7-radius);
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.05);
	color: var(--dc7-white);
	font-size: 1rem;
	transition: border-color 0.2s, box-shadow 0.2s;
}

.dc7-form input:focus,
.dc7-form textarea:focus {
	outline: none;
	border-color: var(--dc7-electric);
	box-shadow: 0 0 0 3px rgba(var(--dc7-electric-rgb), 0.2);
}

.dc7-form textarea {
	min-height: 160px;
	resize: vertical;
}

.dc7-form__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}

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

.dc7-form__field {
	margin-bottom: 1.15rem;
}

.dc7-form__actions {
	margin-top: 0.5rem;
}

.dc7-notice {
	padding: 1rem 1.25rem;
	border-radius: var(--dc7-radius);
	margin-bottom: 1.25rem;
	font-size: 0.9375rem;
}

.dc7-notice--ok {
	background: rgba(34, 197, 94, 0.15);
	border: 1px solid rgba(34, 197, 94, 0.4);
	color: #86efac;
}

.dc7-notice--err {
	background: rgba(239, 68, 68, 0.12);
	border: 1px solid rgba(239, 68, 68, 0.35);
	color: #fca5a5;
}

.dc7-contact-aside {
	padding: 2rem;
	border-radius: var(--dc7-radius-lg);
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.08);
}

.dc7-contact-aside h3 {
	color: var(--dc7-white);
	margin: 0 0 1rem;
	font-size: 1.125rem;
}

.dc7-contact-aside p,
.dc7-contact-aside address {
	color: var(--dc7-muted);
	font-style: normal;
	line-height: 1.7;
	margin: 0 0 1rem;
	font-size: 0.9375rem;
}

.dc7-map {
	margin-top: 1.25rem;
	border-radius: var(--dc7-radius);
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.1);
	aspect-ratio: 16 / 10;
	background: rgba(0, 0, 0, 0.3);
}

.dc7-map iframe {
	width: 100%;
	height: 100%;
	border: 0;
	filter: saturate(0.85) contrast(1.05);
}

/* Illustration Dakar (fallback visuel) */
.dc7-map-fallback {
	width: 100%;
	height: 100%;
	min-height: 200px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 0.5rem;
	background: linear-gradient(180deg, rgba(var(--dc7-electric-rgb), 0.08), rgba(var(--dc7-gold-rgb), 0.06));
	color: var(--dc7-muted);
	font-size: 0.875rem;
	text-align: center;
	padding: 1rem;
}

.dc7-map-fallback strong {
	color: var(--dc7-electric);
	font-size: 1rem;
}

/* Hero compact (pages intérieures) */
.dc7-hero--compact {
	min-height: auto;
	padding: 5rem 1.5rem 3rem;
}

.dc7-hero--compact .dc7-hero__title {
	font-size: clamp(1.85rem, 4vw, 2.75rem);
}

/* Réduction mouvement */
@media (prefers-reduced-motion: reduce) {
	.dc7-btn,
	.dc7-card {
		transition: none;
	}

	.dc7-reveal-prep {
		opacity: 1;
		transform: none;
	}
}
