/* ==========================================
   ROSP FOOTER – PREMIUM FINAL VERSION
========================================== */

.dr1footer {
	position: relative;
	padding: 90px 20px 30px;

	font-family: 'Poppins', 'Segoe UI', sans-serif;

	color: #e5e7eb;

	background:
		linear-gradient(
			180deg,
			#020617 0%,
			#030712 100%
		);

	overflow: hidden;
	isolation: isolate;
}

/* ==========================================
   BACKGROUND IMAGE
========================================== */

.dr1footer .footer-hero-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	overflow: hidden;
}

.dr1footer .footer-hero-bg img {
	position: absolute;
	inset: 0;

	width: 100%;
	height: 100%;

	object-fit: cover;
	object-position: center;

	filter:
		brightness(.45)
		contrast(1.06)
		saturate(1.08);

	transform: scale(1.04);

	animation: footerZoom 18s ease-in-out infinite alternate;
}

/* ==========================================
   OVERLAY
========================================== */

.dr1footer .footer-hero-bg::before {
	content: "";

	position: absolute;
	inset: 0;
	z-index: 1;

	background:
		linear-gradient(
			180deg,
			rgba(2,6,23,.52),
			rgba(2,6,23,.86)
		);
}

/* ==========================================
   GLOW LAYERS
========================================== */

.dr1footer::before {
	content: "";

	position: absolute;
	inset: 0;
	z-index: 1;

	background:
		radial-gradient(
			circle at top left,
			rgba(56,189,248,.14),
			transparent 42%
		),

		radial-gradient(
			circle at bottom right,
			rgba(99,102,241,.14),
			transparent 42%
		);

	pointer-events: none;
}

/* ==========================================
   WRAPPER
========================================== */

.dr1footer .footer-wrapper {
	position: relative;
	z-index: 5;

	max-width: 1250px;
	margin: 0 auto;
}

/* ==========================================
   BRANDING
========================================== */

.dr1footer .footer-branding {
	text-align: center;
	margin-bottom: 70px;
}

.dr1footer .footer-logo {
	width: 150px;
	max-width: 90%;

	margin-bottom: 18px;

	filter:
		drop-shadow(0 14px 40px rgba(0,0,0,.55));

	transition: transform .4s ease;
}

@media (hover:hover) {

	.dr1footer .footer-logo:hover {
		transform: scale(1.04);
	}
}

.dr1footer .footer-tagline {
	font-size: clamp(2rem, 4vw, 3rem);
	font-weight: 800;

	line-height: 1.15;

	color: #ffffff;

	margin-bottom: 12px;

	letter-spacing: -.8px;

	text-shadow:
		0 12px 35px rgba(0,0,0,.5);
}

.dr1footer .footer-subtagline {
	max-width: 720px;

	margin: 0 auto 34px;

	font-size: 1.02rem;
	line-height: 1.9;

	color: #dbeafe;
}

/* ==========================================
   SOCIAL ICONS
========================================== */

.dr1footer .footer-social-icons {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 18px;
}

.dr1footer .footer-social-icons a {
	position: relative;

	width: 50px;
	height: 50px;

	border-radius: 50%;

	display: flex;
	align-items: center;
	justify-content: center;

	text-decoration: none;

	font-size: 18px;

	color: #dbeafe;

	background:
		linear-gradient(
			145deg,
			rgba(255,255,255,.10),
			rgba(255,255,255,.03)
		);

	border:
		1px solid rgba(255,255,255,.12);

	backdrop-filter: blur(16px);

	box-shadow:
		0 15px 40px rgba(0,0,0,.35),
		inset 0 1px 0 rgba(255,255,255,.05);

	overflow: hidden;

	transition:
		transform .35s ease,
		box-shadow .35s ease,
		border-color .35s ease,
		background .35s ease;
}

/* Glow layer */

.dr1footer .footer-social-icons a::before {
	content: "";

	position: absolute;
	inset: -1px;

	border-radius: inherit;

	background:
		linear-gradient(
			135deg,
			rgba(56,189,248,.35),
			rgba(99,102,241,.35),
			rgba(168,85,247,.25)
		);

	opacity: 0;

	transition: opacity .35s ease;
}

.dr1footer .footer-social-icons a i {
	position: relative;
	z-index: 2;
}

/* Hover */

@media (hover:hover) {

	.dr1footer .footer-social-icons a:hover {

		transform:
			translateY(-6px)
			scale(1.08);

		color: #ffffff;

		border-color:
			rgba(56,189,248,.45);

		box-shadow:
			0 25px 60px rgba(59,130,246,.35),
			0 0 35px rgba(99,102,241,.18);
	}

	.dr1footer .footer-social-icons a:hover::before {
		opacity: 1;
	}
}

/* ==========================================
   FOOTER GRID
========================================== */

.dr1footer .footer-grid {
	display: grid;

	grid-template-columns:
		repeat(auto-fit, minmax(220px, 1fr));

	gap: 50px;

	align-items: start;

	margin-bottom: 55px;
}

/* ==========================================
   FOOTER COLUMN
========================================== */

.dr1footer .footer-col h3 {
	position: relative;

	font-size: 1rem;
	font-weight: 700;

	color: #ffffff;

	margin-bottom: 22px;
}

.dr1footer .footer-col h3::after {
	content: "";

	display: block;

	width: 48px;
	height: 2px;

	margin-top: 10px;

	border-radius: 999px;

	background:
		linear-gradient(
			90deg,
			#38bdf8,
			#6366f1
		);
}

/* ==========================================
   LISTS
========================================== */

.dr1footer .footer-col ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.dr1footer .footer-col li {
	margin-bottom: 14px;
}

.dr1footer .footer-col a {
	text-decoration: none;

	font-size: .97rem;
	font-weight: 400;

	color: #cbd5e1;

	transition:
		color .25s ease,
		padding-left .25s ease;
}

.dr1footer .footer-col a:hover {
	color: #ffffff;
	padding-left: 5px;
}

/* ==========================================
   TEXT
========================================== */

.dr1footer .footer-col p {
	font-size: .97rem;
	line-height: 1.85;

	color: #d1d5db;

	margin-bottom: 18px;
}

.dr1footer .footer-col p a {
	color: #93c5fd;
}

.dr1footer .footer-col p a:hover {
	color: #ffffff;
}

/* ==========================================
   ADDRESS
========================================== */

.dr1footer address {
	font-style: normal;
}

/* ==========================================
   FOOTER BOTTOM
========================================== */

.dr1footer .footer-bottom {
	padding-top: 26px;

	border-top:
		1px solid rgba(255,255,255,.08);

	text-align: center;
}

.dr1footer .footer-bottom p {
	margin: 0;

	font-size: .88rem;
	line-height: 1.8;

	color: #9ca3af;
}

.dr1footer .footer-bottom a {
	color: #93c5fd;
	text-decoration: none;
}

.dr1footer .footer-bottom a:hover {
	color: #ffffff;
}

.dr1footer .powered-by {
	margin-top: 8px;
}

/* ==========================================
   ANIMATION
========================================== */

@keyframes footerZoom {

	from {
		transform: scale(1.04);
	}

	to {
		transform: scale(1.10);
	}
}

/* ==========================================
   TABLET & MOBILE
========================================== */

@media (max-width: 768px) {

	.dr1footer {
		padding: 75px 18px 24px;
	}

	/* Better visible background image */

	.dr1footer .footer-hero-bg img {

		object-fit: cover;

		object-position: center top;

		filter:
			brightness(.68)
			contrast(1.05)
			saturate(1.08);

		transform: scale(1);

		animation: none;
	}

	/* lighter overlay */

	.dr1footer .footer-hero-bg::before {

		background:
			linear-gradient(
				180deg,
				rgba(2,6,23,.36),
				rgba(2,6,23,.72)
			);
	}

	.dr1footer .footer-branding {
		margin-bottom: 55px;
	}

	.dr1footer .footer-logo {
		width: 130px;
	}

	.dr1footer .footer-tagline {
		font-size: 2rem;
		line-height: 1.2;
	}

	.dr1footer .footer-subtagline {
		font-size: .96rem;
		line-height: 1.8;
	}

	.dr1footer .footer-grid {
		gap: 38px;
	}

	.dr1footer .footer-col {
		text-align: center;
	}

	.dr1footer .footer-col h3::after {
		margin-left: auto;
		margin-right: auto;
	}

	.dr1footer .footer-social-icons a {
		width: 46px;
		height: 46px;
		font-size: 17px;
	}
}

/* ==========================================
   SMALL MOBILE
========================================== */

@media (max-width: 480px) {

	.dr1footer {
		padding: 68px 14px 22px;
	}

	.dr1footer .footer-tagline {
		font-size: 1.75rem;
	}

	.dr1footer .footer-subtagline {
		font-size: .92rem;
	}

	.dr1footer .footer-grid {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	.dr1footer .footer-social-icons {
		gap: 14px;
	}
}

/* ==========================================
   REDUCED MOTION
========================================== */

@media (prefers-reduced-motion: reduce) {

	.dr1footer * {
		animation: none !important;
		transition: none !important;
	}
}