:root {
	--sba-blue-900: #061A40;
	--sba-blue-700: #0A2472;
	--sba-red: #E63946;
	--sba-white: #FFFFFF;
	--sba-gray: #F5F7FA;
	--sba-glass: rgba(255, 255, 255, 0.08);
	--sba-line: rgba(255, 255, 255, 0.16);
	--sba-radius: 8px;
	--sba-title: "Montserrat", Arial, sans-serif;
	--sba-subtitle: "Outfit", Arial, sans-serif;
	--sba-body: "Poppins", Arial, sans-serif;
}

.sba-section {
	position: relative;
	isolation: isolate;
	overflow: hidden;
	background: var(--sba-blue-900);
	color: var(--sba-white);
	font-family: var(--sba-body);
}

.sba-section-inner {
	width: min(1180px, calc(100% - 40px));
	margin-inline: auto;
	padding-block: clamp(76px, 10vw, 130px);
}

.sba-section-header {
	max-width: 760px;
	margin-bottom: 42px;
}

.sba-section-header h2 {
	margin: 0 0 14px;
	font-family: var(--sba-title);
	font-size: clamp(2.2rem, 5vw, 4.8rem);
	line-height: 0.98;
	letter-spacing: 0;
}

.sba-section-header p {
	margin: 0;
	color: rgba(255, 255, 255, 0.72);
	font-size: clamp(1rem, 2vw, 1.22rem);
}

.sba-hero {
	min-height: 100vh;
	display: grid;
	align-items: end;
	background:
		linear-gradient(90deg, rgba(5, 13, 36, 0.30), rgba(5, 13, 36, 0.10) 46%, rgba(5, 13, 36, 0.18)),
		var(--sba-hero-poster, radial-gradient(circle at 68% 42%, rgba(10, 88, 255, 0.48), transparent 24%)),
		linear-gradient(135deg, var(--sba-blue-900), var(--sba-blue-700));
	background-size: cover;
	background-position: center;
}

.sba-hero-video {
	position: absolute;
	inset: 0;
	z-index: -4;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.sba-hero-overlay {
	position: absolute;
	inset: 0;
	z-index: -3;
	background:
		linear-gradient(180deg, rgba(6, 26, 64, 0.05), rgba(6, 26, 64, 0.18) 46%, rgba(5, 11, 32, 0.46)),
		linear-gradient(90deg, rgba(4, 13, 35, 0.22), rgba(4, 13, 35, 0.04), rgba(4, 13, 35, 0.14));
}

.sba-digital-lines {
	position: absolute;
	inset: auto 0 0;
	z-index: -1;
	height: 42%;
	background:
		linear-gradient(110deg, transparent 0 12%, rgba(230, 57, 70, 0.64) 12.2%, transparent 12.7% 100%),
		linear-gradient(150deg, transparent 0 46%, rgba(0, 113, 255, 0.5) 46.2%, transparent 46.7% 100%),
		linear-gradient(20deg, transparent 0 64%, rgba(255, 255, 255, 0.18) 64.2%, transparent 64.6% 100%);
	filter: drop-shadow(0 0 18px rgba(230, 57, 70, 0.48));
	opacity: 0.76;
}

.sba-particle-canvas {
	position: absolute;
	inset: 0;
	z-index: -2;
	width: 100%;
	height: 100%;
	pointer-events: none;
}

.sba-hero-inner {
	position: relative;
	width: min(1572px, calc(100% - 156px));
	height: 100vh;
	margin-inline: auto;
	padding: 0;
	display: block;
}

.sba-hero-main {
	display: block;
}

.sba-hero-copy {
	position: absolute;
	left: 0;
	top: clamp(168px, 20.6vh, 204px);
	width: min(790px, 100%);
	padding-top: 0;
}

.sba-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 26px;
	color: rgba(255, 255, 255, 0.88);
	font-family: var(--sba-subtitle);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	font-size: 0.86rem;
}

.sba-eyebrow span,
.sba-card-line {
	display: inline-block;
	width: 34px;
	height: 3px;
	background: var(--sba-red);
	box-shadow: 0 0 18px rgba(230, 57, 70, 0.58);
}

.sba-hero h1 {
	margin: 0;
	font-family: var(--sba-title);
	font-size: clamp(4rem, 6.68vw, 7.18rem);
	line-height: 0.89;
	letter-spacing: 0;
	max-width: 9ch;
}

.sba-hero h1 span {
	display: block;
	color: var(--sba-white);
	text-shadow: 0 14px 48px rgba(0, 0, 0, 0.38);
}

.sba-hero h1 .sba-title-red {
	color: #ff0018;
	text-shadow: 0 16px 48px rgba(230, 57, 70, 0.28);
}

.sba-hero p {
	max-width: 650px;
	margin: 22px 0 0;
	color: rgba(255, 255, 255, 0.86);
	font-size: clamp(1rem, 1.42vw, 1.54rem);
	line-height: 1.35;
}

.sba-hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	margin-top: 30px;
}

.sba-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	min-height: 58px;
	padding: 0 30px;
	border-radius: 999px;
	font-family: var(--sba-subtitle);
	font-weight: 800;
	transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
}

.sba-button svg {
	width: 20px;
	height: 20px;
}

.sba-button:hover {
	transform: translateY(-2px);
}

.sba-button-primary {
	background: var(--sba-red);
	color: var(--sba-white);
	box-shadow: 0 18px 54px rgba(230, 57, 70, 0.36);
}

.sba-button-secondary {
	border: 1px solid rgba(255, 255, 255, 0.42);
	background: rgba(255, 255, 255, 0.06);
	color: var(--sba-white);
	backdrop-filter: blur(14px);
}

.sba-hero-info {
	position: absolute;
	right: 4px;
	top: 112px;
	width: 252px;
	margin-top: 0;
	padding: 26px;
	border: 1px solid rgba(255, 255, 255, 0.24);
	border-radius: var(--sba-radius);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.11), rgba(255, 255, 255, 0.045));
	box-shadow: 0 24px 76px rgba(0, 0, 0, 0.26);
	backdrop-filter: blur(18px);
}

.sba-hero-info-location {
	display: flex;
	align-items: center;
	gap: 9px;
	padding-bottom: 18px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.14);
	font-family: var(--sba-subtitle);
	font-weight: 800;
	text-transform: uppercase;
}

.sba-hero-info-location svg {
	width: 18px;
	height: 18px;
	color: var(--sba-red);
}

.sba-hero-weather {
	display: grid;
	grid-template-columns: auto 1fr;
	column-gap: 14px;
	align-items: center;
	padding: 22px 0 18px;
}

.sba-hero-weather svg {
	grid-row: span 2;
	width: 42px;
	height: 42px;
}

.sba-hero-weather strong {
	font-family: var(--sba-title);
	font-size: 3.05rem;
	line-height: 0.95;
}

.sba-hero-weather span,
.sba-hero-time span {
	color: rgba(255, 255, 255, 0.76);
	font-size: 0.92rem;
	line-height: 1.45;
}

.sba-hero-time {
	padding-top: 18px;
	border-top: 3px solid var(--sba-red);
}

.sba-hero-time strong {
	display: block;
	font-family: var(--sba-subtitle);
	font-size: 1.55rem;
	line-height: 1;
}

.sba-hero-cards,
.sba-card-grid,
.sba-dashboard-grid,
.sba-stats-grid,
.sba-gallery-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 26px;
}

.sba-hero-cards {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 70px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.sba-hero-card,
.sba-glass-card,
.sba-metric-card,
.sba-stat-card,
.sba-gallery-item,
.sba-podcast-card {
	position: relative;
	min-height: 224px;
	padding: 24px;
	border: 1px solid var(--sba-line);
	border-radius: var(--sba-radius);
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.10), rgba(255, 255, 255, 0.04)),
		var(--sba-card-image, linear-gradient(135deg, rgba(10, 36, 114, 0.62), rgba(6, 26, 64, 0.88)));
	background-size: cover;
	background-position: center;
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.28);
	backdrop-filter: blur(18px);
	overflow: hidden;
}

.sba-hero-card {
	padding: 25px 24px;
}

.sba-hero-card::before,
.sba-glass-card::before,
.sba-gallery-item::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background: linear-gradient(180deg, rgba(6, 26, 64, 0.42), rgba(6, 26, 64, 0.92));
}

.sba-card-icon {
	width: 58px;
	height: 58px;
	display: inline-grid;
	place-items: center;
	margin-bottom: 18px;
	border-radius: var(--sba-radius);
	background: linear-gradient(135deg, #1258ff, #003fd9);
	color: var(--sba-white);
	box-shadow: 0 14px 36px rgba(18, 88, 255, 0.34);
}

.sba-card-icon svg {
	width: 29px;
	height: 29px;
}

.sba-hero-card:nth-child(even) .sba-card-icon,
.sba-glass-card:nth-child(even) .sba-card-icon {
	background: linear-gradient(135deg, #ff172c, #c70e22);
	box-shadow: 0 14px 36px rgba(230, 57, 70, 0.34);
}

.sba-hero-card h3,
.sba-glass-card h3,
.sba-metric-card h3,
.sba-stat-card h3,
.sba-gallery-item h3,
.sba-podcast-card h3,
.sba-video-card h3 {
	margin: 0 0 8px;
	font-family: var(--sba-subtitle);
	font-size: 1.55rem;
	line-height: 1.18;
	letter-spacing: 0;
}

.sba-hero-card p,
.sba-glass-card p,
.sba-metric-card p,
.sba-stat-card p,
.sba-gallery-item p,
.sba-podcast-card p {
	margin: 0;
	color: rgba(255, 255, 255, 0.76);
}

.sba-card-arrow {
	position: absolute;
	right: 22px;
	bottom: 18px;
	width: 32px;
	height: 32px;
	display: inline-grid;
	place-items: center;
	color: var(--sba-white);
}

.sba-card-arrow svg {
	width: 28px;
	height: 28px;
}

.sba-scroll-indicator {
	position: absolute;
	left: 50%;
	bottom: 18px;
	display: inline-flex;
	align-items: center;
	gap: 12px;
	width: auto;
	height: auto;
	border: 0;
	color: rgba(255, 255, 255, 0.86);
	transform: translateX(-50%);
}

.sba-scroll-indicator > span {
	position: relative;
	left: auto;
	top: auto;
	width: 22px;
	height: 38px;
	border: 1px solid rgba(255, 255, 255, 0.58);
	border-radius: 999px;
	background: transparent;
	transform: none;
	animation: none;
}

.sba-scroll-indicator > span::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 8px;
	width: 4px;
	height: 7px;
	border-radius: 999px;
	background: var(--sba-white);
	transform: translateX(-50%);
	animation: sba-scroll 1.6s infinite;
}

.sba-scroll-indicator em {
	font-style: normal;
	font-size: 0.82rem;
	white-space: nowrap;
}

.sba-scroll-indicator::after {
	content: "";
	width: 16px;
	height: 16px;
	background: currentColor;
	clip-path: polygon(48% 72%, 16% 40%, 24% 32%, 50% 58%, 76% 32%, 84% 40%, 52% 72%);
}

.sba-hero-video-control {
	position: absolute;
	right: min(178px, 10.25vw);
	bottom: 310px;
	display: inline-flex;
	align-items: center;
	gap: 14px;
	font-family: var(--sba-subtitle);
	font-size: 0.85rem;
	font-weight: 800;
}

.sba-video-pause {
	width: 58px;
	height: 58px;
	display: inline-grid;
	place-items: center;
	border: 2px solid rgba(255, 255, 255, 0.68);
	border-radius: 50%;
	background: rgba(10, 36, 114, 0.46);
	box-shadow: 0 0 0 6px rgba(18, 88, 255, 0.12), 0 0 28px rgba(18, 88, 255, 0.56);
	backdrop-filter: blur(10px);
}

.sba-video-pause svg {
	width: 24px;
	height: 24px;
}

.sba-hero-slide-rail {
	position: absolute;
	right: 28px;
	top: 46.5%;
	display: grid;
	gap: 16px;
	justify-items: center;
	align-items: center;
	font-family: var(--sba-title);
	font-weight: 800;
}

.sba-hero-slide-rail i {
	width: 2px;
	height: 92px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.14));
	border-radius: 999px;
}

.sba-hero-slide-rail i::before,
.sba-hero-slide-rail i::after {
	content: "";
	display: block;
	width: 10px;
	height: 10px;
	margin-left: -4px;
	border-radius: 50%;
	background: var(--sba-white);
}

.sba-hero-slide-rail i::after {
	margin-top: 52px;
}

@keyframes sba-scroll {
	0% { transform: translate(-50%, 0); opacity: 1; }
	100% { transform: translate(-50%, 12px); opacity: 0; }
}

.sba-timeline-section,
.sba-gallery-section,
.sba-news-section {
	background:
		radial-gradient(circle at 78% 8%, rgba(230, 57, 70, 0.14), transparent 30%),
		linear-gradient(180deg, #071b42, #061A40);
}

.sba-timeline-track {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: minmax(280px, 380px);
	gap: 18px;
	overflow-x: auto;
	padding: 8px 0 18px;
	scroll-snap-type: x mandatory;
}

.sba-timeline-card {
	scroll-snap-align: start;
	min-height: 240px;
	padding: 24px;
	border: 1px solid var(--sba-line);
	border-radius: var(--sba-radius);
	background: var(--sba-glass);
	backdrop-filter: blur(18px);
}

.sba-timeline-year {
	display: inline-flex;
	margin-bottom: 18px;
	color: var(--sba-red);
	font-family: var(--sba-title);
	font-size: 2rem;
	font-weight: 900;
}

.sba-dashboard {
	position: relative;
	min-height: 560px;
	display: grid;
	align-items: center;
}

.sba-dashboard::before {
	content: "";
	position: absolute;
	inset: 8% 18%;
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 50%;
	box-shadow: inset 0 0 70px rgba(18, 88, 255, 0.18), 0 0 80px rgba(18, 88, 255, 0.16);
}

.sba-dashboard-orbit {
	position: absolute;
	inset: 0;
	pointer-events: none;
}

.sba-dashboard-orbit span {
	position: absolute;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: var(--sba-red);
	box-shadow: 0 0 22px rgba(230, 57, 70, 0.92);
	animation: sba-pulse 2.4s infinite alternate;
}

.sba-dashboard-orbit span:nth-child(1) { left: 18%; top: 28%; }
.sba-dashboard-orbit span:nth-child(2) { left: 66%; top: 16%; animation-delay: 0.6s; }
.sba-dashboard-orbit span:nth-child(3) { left: 78%; top: 72%; animation-delay: 1.1s; }

@keyframes sba-pulse {
	from { transform: scale(0.75); opacity: 0.54; }
	to { transform: scale(1.8); opacity: 1; }
}

.sba-dashboard-grid {
	position: relative;
	z-index: 1;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.sba-metric-card strong {
	display: block;
	margin-bottom: 8px;
	color: var(--sba-red);
	font-family: var(--sba-title);
	font-size: 2.4rem;
	line-height: 1;
}

.sba-map-layout,
.sba-contact-layout {
	display: grid;
	grid-template-columns: minmax(0, 1.4fr) minmax(320px, 0.6fr);
	gap: 24px;
	align-items: stretch;
}

.sba-map-canvas {
	position: relative;
	min-height: 560px;
	border: 1px solid var(--sba-line);
	border-radius: var(--sba-radius);
	background:
		linear-gradient(145deg, rgba(10, 36, 114, 0.45), rgba(6, 26, 64, 0.96)),
		radial-gradient(circle at 42% 48%, rgba(255, 255, 255, 0.12), transparent 42%);
	clip-path: polygon(18% 6%, 70% 2%, 90% 18%, 86% 52%, 96% 78%, 70% 96%, 34% 90%, 10% 66%, 4% 32%);
}

.sba-map-pin {
	position: absolute;
	min-width: 96px;
	min-height: 38px;
	padding: 8px 12px;
	border: 1px solid rgba(255, 255, 255, 0.28);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.10);
	color: var(--sba-white);
	font-family: var(--sba-subtitle);
	font-weight: 700;
	backdrop-filter: blur(12px);
	transform: translate(-50%, -50%);
	cursor: pointer;
}

.sba-map-pin.is-active {
	background: var(--sba-red);
	border-color: var(--sba-red);
	box-shadow: 0 0 40px rgba(230, 57, 70, 0.42);
}

.sba-map-panel {
	border: 1px solid var(--sba-line);
	border-radius: var(--sba-radius);
	background: var(--sba-glass);
	backdrop-filter: blur(18px);
	padding: 24px;
}

.sba-map-card {
	display: none;
}

.sba-map-card.is-active {
	display: block;
}

.sba-filter-bar {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 24px;
}

.sba-filter-bar button {
	min-height: 42px;
	padding: 0 16px;
	border: 1px solid var(--sba-line);
	border-radius: 999px;
	background: var(--sba-glass);
	color: var(--sba-white);
	font-family: var(--sba-subtitle);
	font-weight: 700;
	cursor: pointer;
}

.sba-filter-bar button.is-active {
	background: var(--sba-red);
	border-color: var(--sba-red);
}

.sba-gallery-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.sba-gallery-item {
	min-height: 280px;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
}

.sba-stats-grid {
	grid-template-columns: repeat(6, minmax(0, 1fr));
}

.sba-stat-card {
	min-height: 180px;
}

.sba-stat-card strong,
.sba-stat-card span {
	display: inline;
	color: var(--sba-red);
	font-family: var(--sba-title);
	font-size: 2.5rem;
	font-weight: 900;
	line-height: 1;
}

.sba-video-card {
	border: 1px solid var(--sba-line);
	border-radius: var(--sba-radius);
	background: var(--sba-glass);
	overflow: hidden;
	backdrop-filter: blur(18px);
}

.sba-video-card iframe {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 9;
	border: 0;
}

.sba-video-card h3 {
	padding: 18px;
}

.sba-podcast-list {
	display: grid;
	gap: 18px;
}

.sba-card-link {
	display: inline-flex;
	margin-top: 18px;
	color: var(--sba-red);
	font-family: var(--sba-subtitle);
	font-weight: 800;
}

.sba-news-tools {
	margin-bottom: 24px;
}

.sba-news-tools .search-form {
	display: flex;
	gap: 10px;
	max-width: 560px;
}

.sba-news-tools input[type="search"],
.sba-contact-form input,
.sba-contact-form textarea {
	width: 100%;
	min-height: 48px;
	border: 1px solid var(--sba-line);
	border-radius: var(--sba-radius);
	background: rgba(255, 255, 255, 0.08);
	color: var(--sba-white);
	padding: 12px 14px;
}

.sba-news-tools input[type="submit"],
.sba-contact-form button,
.sba-contact-form input[type="submit"] {
	min-height: 48px;
	border: 0;
	border-radius: 999px;
	background: var(--sba-red);
	color: var(--sba-white);
	padding: 0 20px;
	font-family: var(--sba-subtitle);
	font-weight: 800;
}

.sba-contact-form,
.sba-contact-side {
	border: 1px solid var(--sba-line);
	border-radius: var(--sba-radius);
	background: var(--sba-glass);
	backdrop-filter: blur(18px);
	padding: 24px;
}

.sba-social-links {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-bottom: 20px;
}

.sba-social-links a {
	width: 48px;
	height: 48px;
	display: inline-grid;
	place-items: center;
	border-radius: var(--sba-radius);
	background: var(--sba-red);
}

.sba-map-embed iframe {
	width: 100%;
	border: 0;
	border-radius: var(--sba-radius);
}

.sba-cursor {
	position: fixed;
	left: 0;
	top: 0;
	z-index: 9999;
	width: 20px;
	height: 20px;
	border: 1px solid rgba(255, 255, 255, 0.62);
	border-radius: 50%;
	pointer-events: none;
	transform: translate(-50%, -50%);
	transition: width 140ms ease, height 140ms ease, background 140ms ease;
	mix-blend-mode: difference;
}

.sba-cursor.is-active {
	width: 44px;
	height: 44px;
	background: rgba(230, 57, 70, 0.18);
}

@media (max-width: 1080px) {
	.sba-hero-inner {
		width: min(100% - 40px, 1180px);
		height: auto;
		padding: 130px 0 72px;
		display: grid;
		gap: 30px;
	}

	.sba-hero-main {
		display: grid;
		grid-template-columns: 1fr;
	}

	.sba-hero-info,
	.sba-hero-video-control,
	.sba-hero-slide-rail {
		display: none;
	}

	.sba-hero-copy,
	.sba-hero-cards {
		position: static;
	}

	.sba-hero-cards,
	.sba-card-grid,
	.sba-dashboard-grid,
	.sba-gallery-grid,
	.sba-stats-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.sba-map-layout,
	.sba-contact-layout {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 680px) {
	.sba-section-inner,
	.sba-hero-inner {
		width: min(100% - 28px, 1180px);
	}

	.sba-hero {
		min-height: 100svh;
	}

	.sba-hero h1 {
		font-size: clamp(3.2rem, 18vw, 5.4rem);
	}

	.sba-hero-copy {
		padding-top: 0;
	}

	.sba-hero-cards,
	.sba-card-grid,
	.sba-dashboard-grid,
	.sba-gallery-grid,
	.sba-stats-grid {
		grid-template-columns: 1fr;
	}

	.sba-map-canvas {
		min-height: 430px;
	}

	.sba-map-pin {
		min-width: 78px;
		font-size: 0.76rem;
	}

	.sba-news-tools .search-form {
		flex-direction: column;
	}
}

@media (prefers-reduced-motion: reduce) {
	.sba-scroll-indicator span,
	.sba-dashboard-orbit span {
		animation: none;
	}
}
