/**
 * Footer BJ66 — 3 cột (override app.css legacy `footer {}`)
 */
footer.bj66-footer,
.bj66-footer {
	position: relative;
	z-index: 3;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	overflow-x: hidden;
	background: linear-gradient(180deg, #0d0d0d 0%, #121212 100%) !important;
	border-top: 4px solid #c30000 !important;
	color: #e8eaed;
	margin-top: 0;
}

.bj66-footer *,
.bj66-footer *::before,
.bj66-footer *::after {
	box-sizing: border-box;
}

.bj66-footer__main {
	width: 100%;
	max-width: 100%;
	padding: 3rem 1.25rem 2.5rem;
}

.bj66-footer__grid {
	display: grid;
	grid-template-columns: 1.2fr 0.9fr 1fr;
	gap: 2.5rem 2rem;
	align-items: start;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
}

.bj66-footer__col {
	min-width: 0;
}

.bj66-footer__col--brand {
	max-width: 360px;
}

.bj66-footer__logo-link {
	display: inline-block;
	margin-bottom: 1rem;
}

.bj66-footer__logo {
	width: 120px;
	height: auto;
	display: block;
	filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.35));
}

.bj66-footer__intro {
	font-size: 0.9375rem;
	line-height: 1.75;
	color: #b8bcc4;
	margin: 0;
	text-align: left;
}

.bj66-footer__title {
	margin: 0 0 1.15rem;
	padding: 0;
	font-family: 'Finger Paint', 'Tomorrow', sans-serif;
	font-size: 1.125rem;
	font-weight: 700;
	color: #f98d05 !important;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.bj66-footer__menu,
.bj66-footer__contact {
	list-style: none !important;
	margin: 0;
	padding: 0;
}

.bj66-footer__menu li,
.bj66-footer__contact li {
	margin: 0 0 0.65rem;
	padding: 0;
}

.bj66-footer__menu a,
.bj66-footer__contact a {
	color: #f0f2f5 !important;
	font-size: 0.9375rem;
	text-decoration: none;
	transition: color 0.2s ease;
}

.bj66-footer__menu a:hover,
.bj66-footer__contact a:hover {
	color: #ffd259 !important;
}

.bj66-footer__contact li {
	display: flex;
	align-items: flex-start;
	gap: 0.65rem;
	font-size: 0.9375rem;
	line-height: 1.55;
	color: #d0d4dc;
}

.bj66-footer__contact i {
	flex-shrink: 0;
	width: 1.1rem;
	margin-top: 0.2rem;
	color: #f98d05;
	font-size: 0.95rem;
	text-align: center;
}

.bj66-footer__bottom {
	width: 100%;
	background: #c30000 !important;
	text-align: center;
	padding: 0.65rem 1rem;
}

.bj66-footer__bottom p {
	margin: 0;
	color: #fff !important;
	font-size: 0.875rem;
}

.bj66-footer__bottom strong {
	font-weight: 700;
	color: #fff !important;
}

@media (max-width: 991px) {
	.bj66-footer__grid {
		grid-template-columns: 1fr 1fr;
		gap: 2rem 1.5rem;
	}

	.bj66-footer__col--brand {
		grid-column: 1 / -1;
		max-width: none;
		text-align: center;
	}

	.bj66-footer__logo-link {
		margin-left: auto;
		margin-right: auto;
	}

	.bj66-footer__intro {
		text-align: center;
		max-width: 520px;
		margin-left: auto;
		margin-right: auto;
	}
}

@media (max-width: 767px) {
	.bj66-footer__main {
		padding: 2.25rem 16px 1.75rem;
	}

	.bj66-footer__grid {
		grid-template-columns: 1fr;
		gap: 1.75rem;
	}

	.bj66-footer__col--brand {
		grid-column: auto;
	}

	.bj66-footer__col--links,
	.bj66-footer__col--contact {
		padding-left: 0.25rem;
	}

	.bj66-footer__title {
		margin-bottom: 0.85rem;
		font-size: 1.05rem;
	}

	.bj66-footer__intro {
		font-size: 0.9rem;
	}

	.bj66-footer__bottom {
		padding: 0.65rem 16px;
	}
}

@media (max-width: 575px) {
	.bj66-footer__main {
		padding: 2rem 12px 1.5rem;
	}

	.bj66-footer__bottom {
		padding: 0.6rem 12px;
	}
}
