@import url('https://fonts.googleapis.com/css2?family=Public+Sans:wght@400;500;700&display=swap');

:root {
	--primary: #2563eb;
	--primary-dark: #1d4ed8;
	--accent: #f59e0b;
	--accent-dark: #d97706;
	--success: #10b981;
	--success-dark: #059669;
	--info: #6366f1;
	--info-dark: #4f46e5;
	--dark: #0f172a;
	--light: #f8fafc;
	--glass: rgba(255, 255, 255, 0.85);
	--glass-border: rgba(255, 255, 255, 0.125);
	--shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
	--shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
	--transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

* {
	font-family: "Public Sans", sans-serif;
}

body {
	background: #ffffff;
	color: var(--dark);
}

.section-padding {
	padding: 120px 0;
}

h2 {
	font-size: 2.5rem;
	font-weight: 800;
	letter-spacing: -0.02em;
}

/* --- Navbar --- */
.navbar {
	transition: var(--transition);
	padding: 1rem 0;
	box-shadow: 0 0 28px 0 rgba(175, 193, 223, .3);
}

.navbar.scrolled {
	background: var(--glass) !important;
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	box-shadow: var(--shadow);
	padding: 0.75rem 0;
}

.navbar-brand img {
	transition: var(--transition);
}

.navbar.scrolled .navbar-brand img {
	width: 240px !important;
}

.navbar-toggler {
	padding: 1px 5px;
	font-size: 18px;
	line-height: 0.3;
	background: #fff;
}

.nav-link {
	font-weight: 600;
	transition: var(--transition);
	position: relative;
	font-size: 17px;
}

.nav-link::after {
	content: '';
	position: absolute;
	width: 0;
	height: 2px;
	bottom: 0;
	left: 50%;
	background-color: var(--primary);
	transition: var(--transition);
	transform: translateX(-50%);
}

.navbar-light .navbar-nav .nav-link:hover {
	color: #000;
}

.navbar-light .navbar-nav .nav-link {
	color: #202e44;
}

.nav-link:hover::after {
	width: 100%;
}

/* --- Buttons --- */
.btn {
	padding: 0.75rem 1.75rem;
	font-weight: 600;
	border-radius: 8px;
	transition: var(--transition);
	text-transform: none;
	letter-spacing: 0;
}

.btn-primary {
	background-color: var(--primary);
	border-color: var(--primary);
}

.btn-primary:hover {
	background-color: var(--primary-dark);
	border-color: var(--primary-dark);
	transform: translateY(-2px);
	box-shadow: var(--shadow);
}

.btn-warning {
	background-color: var(--accent);
	border-color: var(--accent);
	color: white;
}

.btn-warning:hover {
	background-color: var(--accent-dark);
	border-color: var(--accent-dark);
	color: white;
	transform: translateY(-2px);
	box-shadow: var(--shadow);
}

/* --- Carousel / Hero --- */
.carousel-item {
	position: relative;
	height: 600px;
	min-height: 300px;
}

.carousel-inner::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: linear-gradient(to bottom, rgba(0, 0, 0, 0.4) 0%, rgba(0, 0, 0, 0.7) 100%) !important;
	z-index: 1;
}

.carousel-item img {
	height: 100%;
	width: 100%;
	object-fit: cover;
}

.carousel-caption {
	text-align: left;
	max-width: 800px;
	left: 10%;
	bottom: 20% !important;
	z-index: 2;
}

.carousel-caption h5 {
	font-size: 3.5rem;
	font-weight: 800;
	text-transform: none !important;
	letter-spacing: -0.02em !important;
	line-height: 1.1;
	margin-bottom: 1.5rem;
}

.carousel-caption p {
	font-size: 1.25rem;
	margin: 0 0 2rem 0 !important;
	width: 100% !important;
	opacity: 0.9;
}

/* --- Section Cards --- */
/* Base Card Style */
.beneficio-box,
.funciona-box,
.requisito-box,
.seguridad-box {
	background: white;
	border: 1px solid rgba(0, 0, 0, 0.05);
	transition: var(--transition);
	border-radius: 16px !important;
	height: 100%;
}

.beneficio-box:hover,
.funciona-box:hover,
.requisito-box:hover,
.seguridad-box:hover {
	transform: translateY(-10px);
	box-shadow: var(--shadow-lg);
}

/* Base Icon Style */
.beneficio-icon,
.funciona-icon,
.requisito-icon,
.seguridad-icon {
	width: 64px;
	height: 64px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.75rem;
	transition: var(--transition);
}

/* Color Variations */
.beneficio-box:hover {
	border-color: var(--primary);
}

.beneficio-icon {
	background-color: rgba(37, 99, 235, 0.1);
	color: var(--primary);
}

.beneficio-box:hover .beneficio-icon {
	background-color: var(--primary);
	color: white;
	transform: scale(1.1);
}

.funciona-box:hover {
	border-color: var(--accent);
}

.funciona-icon {
	background-color: rgba(245, 158, 11, 0.1);
	color: var(--accent);
}

.funciona-box:hover .funciona-icon {
	background-color: var(--accent);
	color: white;
	transform: scale(1.1);
}

.requisito-box:hover {
	border-color: var(--success);
}

.requisito-icon {
	background-color: rgba(16, 185, 129, 0.1);
	color: var(--success);
}

.requisito-box:hover .requisito-icon {
	background-color: var(--success);
	color: white;
	transform: scale(1.1);
}

.seguridad-box:hover {
	border-color: var(--info);
}

.seguridad-icon {
	background-color: rgba(99, 102, 241, 0.1);
	color: var(--info);
}

.seguridad-box:hover .seguridad-icon {
	background-color: var(--info);
	color: white;
	transform: scale(1.1);
}

/* --- Footer --- */
.footer {
	background-color: white;
	border-top: 1px solid rgba(0, 0, 0, 0.05);
	color: #64748b;
}

.footer h6 {
	color: var(--dark);
	font-size: 1.1rem;
	letter-spacing: -0.01em;
}

.footer-link {
	color: #64748b;
	text-decoration: none;
	transition: var(--transition);
	display: inline-block;
	margin-bottom: 0.5rem;
}

.footer-link:hover {
	color: var(--primary);
	transform: translateX(5px);
}

.footer-contact-icon {
	width: 32px;
	height: 32px;
	background-color: var(--light);
	color: var(--primary);
	border-radius: 8px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-right: 12px;
	font-size: 0.9rem;
	transition: var(--transition);
}

.footer-link:hover .footer-contact-icon {
	background-color: var(--primary);
	color: white;
}

.footer-copyright {
	background-color: var(--light);
	border-top: 1px solid rgba(0, 0, 0, 0.05);
	font-size: 0.9rem;
}

/* --- Utils --- */
.card {
	margin-bottom: 30px;
}

/* --- Mobile Adjustments --- */
@media (max-width: 768px) {
	.section-padding {
		padding: 60px 0;
	}

	.carousel-item {
		height: 550px;
	}

	.carousel-caption {
		left: 5% !important;
		right: 5% !important;
		bottom: 8% !important;
		text-align: center !important;
		max-width: 94% !important;
		padding: 1.5rem !important;
		background: rgba(15, 23, 42, 0.7);
		border-radius: 20px;
		margin: 0 auto;
	}

	.carousel-caption h5 {
		font-size: 1.75rem !important;
		margin-bottom: 0.75rem !important;
		line-height: 1.2;
	}

	.carousel-caption p {
		font-size: 1.1rem !important;
		margin-bottom: 1.25rem !important;
	}

	.carousel-caption .d-flex {
		flex-direction: column !important;
		gap: 0.75rem !important;
		align-items: center;
	}

	.carousel-caption .btn {
		width: 100% !important;
		max-width: 280px;
		padding: 0.75rem 1.5rem !important;
	}

	/* Neutralize AOS delays on mobile for a snappier feel */
	[data-aos][data-aos-delay] {
		transition-delay: 0s !important;
		animation-delay: 0s !important;
	}
}