/* =========================================================
   EurêCard — Footer global
   Palette alignée sur variables.css : PRIMARY = ROUGE Pokéball #fe0201.
   Or (#facc15 / --idd-semantic-favorite) reste l'accent secondaire.
   ========================================================= */

.pkb-site-footer {
	position: relative;
	margin-top: 80px;
	background:
		linear-gradient(180deg, transparent 0%, rgba(0,0,0,.4) 30%),
		radial-gradient(ellipse at top left, rgba(254,2,1,.18), transparent 45%),
		radial-gradient(ellipse at bottom right, rgba(250,204,21,.10), transparent 50%),
		linear-gradient(135deg, var(--idd-color-bg-dark, #0a0f1f) 0%, var(--idd-color-bg-dark-alt, #111827) 50%, var(--idd-color-bg-dark, #0f172a) 100%);
	color: rgba(255,255,255,.82);
	border-top: 1px solid rgba(250,204,21,.18);
	overflow: hidden;
}

.pkb-footer-glow {
	position: absolute;
	top: -100px; left: 50%;
	transform: translateX(-50%);
	width: 600px; height: 200px;
	background: radial-gradient(ellipse, rgba(254,2,1,.4), transparent 70%);
	filter: blur(60px);
	pointer-events: none;
}

.pkb-footer-inner {
	width: min(var(--pkb-container, 1680px), 100%);
	margin: 0 auto;
	padding: 56px var(--pkb-container-padding, 14px) 28px;
	position: relative;
	z-index: 1;
}

.pkb-footer-hero {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 40px;
	align-items: center;
	padding-bottom: 36px;
	margin-bottom: 36px;
	border-bottom: 1px solid rgba(255,255,255,.08);
}

.pkb-footer-logo-img { max-height: 56px; max-width: 220px; display: block; margin-bottom: 12px; }
.pkb-footer-logo-text {
	display: inline-block;
	font-size: 32px;
	font-weight: 900;
	letter-spacing: -0.04em;
	color: #fff;
	margin-bottom: 12px;
	background: linear-gradient(135deg, #fff 0%, var(--idd-semantic-favorite, #facc15) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}
.pkb-footer-tagline {
	font-size: 17px;
	font-weight: 700;
	color: rgba(255,255,255,.95);
	margin: 0 0 6px;
	line-height: 1.4;
}
.pkb-footer-pitch {
	color: rgba(255,255,255,.7);
	margin: 0;
	max-width: 520px;
	line-height: 1.6;
	font-size: 14px;
}

.pkb-footer-cta {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	justify-content: flex-end;
}
.pkb-footer-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 13px 22px;
	border-radius: 12px;
	font-weight: 800;
	font-size: 14px;
	text-decoration: none;
	transition: transform .15s ease, box-shadow .15s ease;
}
.pkb-footer-btn--primary {
	background: linear-gradient(135deg, var(--pkb-primary, #fe0201), var(--pkb-primary-hover, #d40000));
	color: #fff;
	box-shadow: 0 8px 20px rgba(254,2,1,.35);
}
.pkb-footer-btn--ghost {
	background: rgba(255,255,255,.08);
	border: 1px solid rgba(255,255,255,.14);
	color: #fff;
}
.pkb-footer-btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 28px rgba(254,2,1,.45);
}
.pkb-footer-btn--ghost:hover { background: rgba(255,255,255,.14); }

.pkb-footer-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 22px;
	margin-bottom: 36px;
}

.pkb-footer-col {
	padding: 22px;
	border-radius: 18px;
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.07);
	backdrop-filter: blur(10px);
	transition: border-color .2s ease, transform .2s ease;
}
.pkb-footer-col:hover {
	border-color: rgba(250,204,21,.25);
	transform: translateY(-2px);
}

.pkb-footer-col h3 {
	margin: 0 0 14px;
	color: var(--idd-semantic-favorite, #facc15);
	font-size: 13px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .08em;
}

.pkb-footer-col ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 9px;
}

.pkb-footer-col a,
.pkb-footer-cookie-btn {
	color: rgba(255,255,255,.78);
	text-decoration: none;
	font-weight: 600;
	font-size: 14px;
	transition: color .12s ease, transform .12s ease;
	background: none;
	border: 0;
	padding: 0;
	cursor: pointer;
	font-family: inherit;
	text-align: left;
	display: inline-block;
}
.pkb-footer-col a:hover,
.pkb-footer-cookie-btn:hover {
	color: #fff;
	transform: translateX(3px);
}

.pkb-footer-disclaimer {
	padding: 18px 22px;
	background: rgba(254,2,1,.06);
	border: 1px solid rgba(254,2,1,.18);
	border-radius: 16px;
	margin-bottom: 24px;
	font-size: 13px;
	color: rgba(255,255,255,.7);
	line-height: 1.6;
}
.pkb-footer-disclaimer p { margin: 0 0 6px; }
.pkb-footer-disclaimer p:last-child { margin: 0; }
.pkb-footer-disclaimer-sources a {
	color: rgba(250,204,21,.85);
	text-decoration: none;
	font-weight: 700;
}
.pkb-footer-disclaimer-sources a:hover { color: var(--idd-semantic-favorite, #facc15); text-decoration: underline; }

.pkb-footer-social-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
	padding: 18px 0;
	margin-bottom: 18px;
	border-top: 1px solid rgba(255,255,255,.07);
	border-bottom: 1px solid rgba(255,255,255,.07);
}
.pkb-footer-socials {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}
.pkb-footer-social-label {
	color: rgba(255,255,255,.6);
	font-size: 13px;
	font-weight: 700;
	margin-right: 6px;
}
.pkb-footer-social {
	width: 40px; height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 12px;
	background: rgba(255,255,255,.06);
	color: rgba(255,255,255,.85);
	transition: transform .15s ease, background .15s ease, color .15s ease;
}
.pkb-footer-social:hover { transform: translateY(-3px) scale(1.05); color: #fff; }
.pkb-footer-social--facebook:hover  { background: #1877f2; }
.pkb-footer-social--instagram:hover { background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%); }
.pkb-footer-social--twitter:hover   { background: #000; }
.pkb-footer-social--linkedin:hover  { background: #0a66c2; }
.pkb-footer-social--youtube:hover   { background: #ff0000; }
.pkb-footer-social--tiktok:hover    { background: #000; }
.pkb-footer-social--discord:hover   { background: #5865f2; }
.pkb-footer-social--twitch:hover    { background: #9146ff; }
.pkb-footer-social--threads:hover   { background: #000; }

.pkb-footer-contact-mail {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
}
.pkb-footer-contact-label { color: rgba(255,255,255,.7); font-weight: 600; }
.pkb-footer-contact-mail a {
	color: var(--idd-semantic-favorite, #facc15);
	text-decoration: none;
	font-weight: 700;
}
.pkb-footer-contact-mail a:hover { text-decoration: underline; }

.pkb-footer-bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	flex-wrap: wrap;
	font-size: 13px;
	color: rgba(255,255,255,.6);
}
.pkb-footer-copyright { margin: 0; }
.pkb-footer-mini-legal {
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 6px 12px;
}
.pkb-footer-mini-legal a {
	color: rgba(255,255,255,.6);
	text-decoration: none;
	transition: color .12s ease;
}
.pkb-footer-mini-legal a:hover { color: var(--idd-semantic-favorite, #facc15); }

/* ════════════ CRÉDITS AGENCE — discret, premium, hover doré ════════════ */
.pkb-footer-credits {
	margin: 0;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 12.5px;
	color: rgba(255,255,255,.55);
	letter-spacing: .01em;
}

.pkb-footer-credits-prefix {
	font-weight: 400;
}

.pkb-footer-credits-link {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 2px 8px;
	border-radius: 999px;
	background: rgba(255,255,255,.04);
	color: rgba(255,255,255,.92);
	text-decoration: none;
	font-weight: 700;
	letter-spacing: .005em;
	transition: background .18s ease, color .18s ease, transform .18s ease;
	border: 1px solid rgba(255,255,255,.06);
}

.pkb-footer-credits-link:hover,
.pkb-footer-credits-link:focus-visible {
	background: rgba(250, 204, 21, .14);
	color: var(--idd-semantic-favorite, #facc15);
	transform: translateY(-1px);
	border-color: rgba(250, 204, 21, .35);
	outline: none;
}

.pkb-footer-credits-name {
	background: linear-gradient(135deg, #fff 0%, rgba(255,255,255,.85) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

.pkb-footer-credits-link:hover .pkb-footer-credits-name,
.pkb-footer-credits-link:focus-visible .pkb-footer-credits-name {
	background: linear-gradient(135deg, var(--idd-semantic-favorite, #facc15) 0%, #fde047 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

.pkb-footer-credits-arrow {
	opacity: .55;
	transition: transform .22s ease, opacity .22s ease;
}

.pkb-footer-credits-link:hover .pkb-footer-credits-arrow,
.pkb-footer-credits-link:focus-visible .pkb-footer-credits-arrow {
	opacity: 1;
	transform: translate(1px, -1px);
}

@media (max-width: 640px) {
	.pkb-footer-credits { font-size: 12px; flex-wrap: wrap; }
}

@media (max-width: 960px) {
	.pkb-footer-grid { grid-template-columns: repeat(2, 1fr); }
	.pkb-footer-hero { grid-template-columns: 1fr; }
	.pkb-footer-cta { justify-content: flex-start; }
}
@media (max-width: 640px) {
	.pkb-site-footer { margin-top: 48px; }
	.pkb-footer-inner { padding-top: 36px; }
	.pkb-footer-grid { grid-template-columns: 1fr; gap: 14px; }
	.pkb-footer-col { padding: 18px; border-radius: 14px; }
	.pkb-footer-logo-text { font-size: 26px; }
	.pkb-footer-tagline { font-size: 15px; }
	.pkb-footer-bottom { flex-direction: column; align-items: flex-start; }
	.pkb-footer-social-row { flex-direction: column; align-items: flex-start; }
}
