/* Minimal custom styles */
body {
	font-family: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}

/* Global dark theme base */
[data-bs-theme="dark"] body {
	background-color: #0b1a2c;
	color: #fff;
}
[data-bs-theme="dark"] a { color: #6aa8ff; }
[data-bs-theme="dark"] a:hover { color: #99c4ff; }
[data-bs-theme="dark"] .text-secondary { color: rgba(255,255,255,.7) !important; }
[data-bs-theme="dark"] .bg-light { background-color: #0f1f35 !important; }
[data-bs-theme="dark"] .card { background-color: #0f1b2c; border-color: rgba(255,255,255,.08); color: #fff; }
[data-bs-theme="dark"] .card .card-text { color: rgba(255,255,255,.8); }
[data-bs-theme="dark"] .list-group-item { background-color: #0f1b2c; color: #fff; border-color: rgba(255,255,255,.08); }
[data-bs-theme="dark"] .modal-content { background-color: #0f1b2c; color: #fff; border-color: rgba(255,255,255,.1); }
[data-bs-theme="dark"] .dropdown-menu { background-color: #0f1b2c; color: #fff; border-color: rgba(255,255,255,.08); }
[data-bs-theme="dark"] .table { color: #fff; }
[data-bs-theme="dark"] .table thead th { color: #fff; border-color: rgba(255,255,255,.12); }
[data-bs-theme="dark"] .table td, [data-bs-theme="dark"] .table th { border-color: rgba(255,255,255,.08); }
[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select,
[data-bs-theme="dark"] .form-control:focus,
[data-bs-theme="dark"] .form-select:focus {
	background-color: #0f1f35;
	color: #fff;
	border-color: rgba(255,255,255,.18);
}
[data-bs-theme="dark"] ::placeholder { color: rgba(255,255,255,.55) !important; }
[data-bs-theme="dark"] .btn-outline-secondary { color: #fff; border-color: rgba(255,255,255,.5); }
[data-bs-theme="dark"] .btn-outline-secondary:hover { background: rgba(255,255,255,.1); }
[data-bs-theme="dark"] hr { border-color: rgba(255,255,255,.12); }

/* Modern dark capabilities section */
.capabilities-dark { background: radial-gradient(120% 120% at 50% -10%, rgba(106,168,255,.08), transparent 50%), linear-gradient(180deg, #0b1a2c, #0c1c30); border-top: 1px solid rgba(255,255,255,.06); border-bottom: 1px solid rgba(255,255,255,.06); }
.capabilities-dark .section-head .badge { background: rgba(106,168,255,.14); color: #cfe2ff; border: 1px solid rgba(106,168,255,.35); letter-spacing: .12em; }
.capabilities-dark .section-title { color: #fff; text-shadow: 0 8px 22px rgba(0,0,0,.45); }
.capabilities-dark .section-subtitle { color: rgba(255,255,255,.8) !important; }
.capabilities-dark .feature-card.pro {
	background: rgba(255,255,255,.02);
	border: 1px solid rgba(255,255,255,.08);
	border-radius: .9rem;
	box-shadow: 0 8px 24px rgba(0,0,0,.25);
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease, background-color .25s ease;
}
.capabilities-dark .feature-card.pro:hover { transform: translateY(-4px); box-shadow: 0 14px 36px rgba(0,0,0,.35); border-color: rgba(106,168,255,.35); background: rgba(255,255,255,.03); }
.capabilities-dark .feature-card.pro i { color: #6aa8ff; filter: drop-shadow(0 6px 18px rgba(106,168,255,.35)); transition: transform .25s ease; font-size: 2.2rem; }
.capabilities-dark .feature-card.pro h3 { color: #fff; font-weight: 700; font-size: 1.15rem; letter-spacing: .2px; }
.capabilities-dark .feature-card.pro p { color: rgba(255,255,255,.84) !important; line-height: 1.55; }
.capabilities-dark .feature-card.pro .fc-glow { position: absolute; left: 10%; right: 10%; bottom: -14px; height: 18px; background: radial-gradient(50% 50% at 50% 50%, rgba(106,168,255,.35), transparent 70%); filter: blur(6px); opacity: .5; transition: opacity .35s ease; pointer-events: none; }
.capabilities-dark .feature-card.pro:hover .fc-glow { opacity: .8; }
/* Arrow hover cue and subtle icon animation */
.capabilities-dark .feature-card.pro .fc-arrow { position: absolute; right: 12px; bottom: 12px; font-size: 1.1rem; color: rgba(255,255,255,.65); opacity: 0; transform: translateY(4px); transition: opacity .2s ease, transform .2s ease; }
.capabilities-dark .feature-card.pro:hover .fc-arrow { opacity: 1; transform: none; }
.capabilities-dark .feature-card.pro:hover i { transform: translateY(-2px) scale(1.04); }

.nav-modern {
    position: sticky;
    top: 0;
    z-index: 1040;
    backdrop-filter: none;
    background: transparent;
    border-bottom: 0;
    transition: background-color .2s ease, backdrop-filter .2s ease, border-color .2s ease;
}
.nav-modern.over-hero {
    position: fixed;
    width: 100%;
    background: transparent; /* no background over hero */
    border-bottom-color: transparent;
}
.nav-modern.over-hero .navbar .nav-link { color: rgba(255,255,255,.9); opacity: .9; }
.nav-modern.over-hero .navbar .nav-link:hover, .nav-modern.over-hero .navbar .nav-link.active { color: #fff; opacity: 1; }
.nav-modern.over-hero .navbar-brand span { color: #fff; }
.nav-modern.over-hero .social-links a { color: rgba(255,255,255,.85); }
.nav-modern.over-hero .social-links a:hover { color: #fff; }
.nav-modern.over-hero .btn.btn-outline-secondary.btn-sm { color: #fff; border-color: rgba(255,255,255,.5); }
.nav-modern.over-hero .dropdown-menu { background: rgba(16,30,48,.95); color: #fff; }
.nav-modern.over-hero .dropdown-item { color: rgba(255,255,255,.9); }
.nav-modern.over-hero .dropdown-item:hover { background: rgba(255,255,255,.08); color: #fff; }

/* Theme support for non-hero pages */
[data-bs-theme="dark"] .nav-modern:not(.over-hero) { background: transparent; border-bottom-color: transparent; }

/* On-scroll header background */
.nav-modern.scrolled { backdrop-filter: saturate(180%) blur(8px); background: rgba(255,255,255,.9); border-bottom: 1px solid rgba(0,0,0,.06); }
[data-bs-theme="dark"] .nav-modern.scrolled { background: rgba(10, 26, 43, .9); border-bottom-color: rgba(255,255,255,.12); }

/* Ensure readable link colors when scrolled */
.nav-modern.scrolled .navbar .nav-link { color: #0b2239; opacity: .9; }
.nav-modern.scrolled .navbar .nav-link:hover, .nav-modern.scrolled .navbar .nav-link.active { color: #0d6efd; opacity: 1; }
.nav-modern.scrolled .navbar-brand span { color: #0b2239; }
[data-bs-theme="dark"] .nav-modern.scrolled .navbar .nav-link { color: rgba(255,255,255,.9); }
[data-bs-theme="dark"] .nav-modern.scrolled .navbar .nav-link:hover, [data-bs-theme="dark"] .nav-modern.scrolled .navbar .nav-link.active { color: #fff; }
[data-bs-theme="dark"] .nav-modern.scrolled .navbar-brand span { color: #fff; }
[data-bs-theme="dark"] .nav-modern:not(.over-hero) .navbar .nav-link { color: rgba(255,255,255,.9); }
[data-bs-theme="dark"] .nav-modern:not(.over-hero) .navbar .nav-link:hover, [data-bs-theme="dark"] .nav-modern:not(.over-hero) .navbar .nav-link.active { color: #fff; }
[data-bs-theme="dark"] .nav-modern:not(.over-hero) .btn.btn-outline-secondary.btn-sm { color: #fff; border-color: rgba(255,255,255,.5); }
[data-bs-theme="dark"] .dropdown-menu { background: #0f1b2c; color: #fff; }
[data-bs-theme="dark"] .dropdown-item { color: rgba(255,255,255,.9); }
[data-bs-theme="dark"] .dropdown-item:hover { background: rgba(255,255,255,.08); color: #fff; }
.nav-modern .navbar { padding-top: .85rem; padding-bottom: .85rem; }
.nav-modern .navbar-brand img { height: 44px; }
.nav-modern .navbar .nav-link { text-transform: uppercase; letter-spacing: .02em; font-weight: 600; }
.nav-modern .navbar .dropdown-menu { border-radius: .5rem; }
.nav-modern .navbar .dropdown-item { padding: .5rem .75rem; }

/* Responsive header/logo sizing */
@media (max-width: 576px) {
	.nav-modern .navbar { padding-top: .5rem; padding-bottom: .5rem; }
	.nav-modern .navbar-brand img { height: 32px; }
}
@media (min-width: 992px) {
	.nav-modern .navbar { padding-top: 1rem; padding-bottom: 1rem; }
	.nav-modern .navbar-brand img { height: 56px; }
}
@media (min-width: 1400px) {
	.nav-modern .navbar { padding-top: 1.15rem; padding-bottom: 1.15rem; }
	.nav-modern .navbar-brand img { height: 60px; }
}
.nav-modern .navbar .nav-link {
	color: #0b2239;
	opacity: .85;
	transition: color .2s ease, opacity .2s ease;
}
.nav-modern .navbar .nav-link:hover, .nav-modern .navbar .nav-link.active {
	opacity: 1;
	color: #0d6efd;
}
.nav-modern .navbar-brand span { letter-spacing: .3px; }
.nav-modern .btn.btn-primary.btn-sm { box-shadow: 0 6px 16px rgba(13,110,253,.25); }

/* Desktop hover dropdown with animation (keeps mobile click behavior) */
@media (min-width: 992px) {
    /* Prepare menu for animation */
    .nav-modern .navbar .navbar-nav .dropdown .dropdown-menu {
        display: block; /* allow transition */
        opacity: 0;
        visibility: hidden;
        transform: translateY(8px);
        transition: transform .18s ease, opacity .18s ease, visibility 0s linear .18s;
        pointer-events: none;
    }
    /* Reveal on hover/focus */
    .nav-modern .navbar .navbar-nav .dropdown:hover > .dropdown-menu,
    .nav-modern .navbar .navbar-nav .dropdown:focus-within > .dropdown-menu {
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
        transition-delay: 0s;
        pointer-events: auto;
    }
    /* Optional: animate caret */
    .nav-modern .navbar .navbar-nav .dropdown .dropdown-toggle::after { transition: transform .18s ease; }
    .nav-modern .navbar .navbar-nav .dropdown:hover .dropdown-toggle::after,
    .nav-modern .navbar .navbar-nav .dropdown:focus-within .dropdown-toggle::after { transform: rotate(180deg); }
}

/* Global dropdown animation (all menus) */
.dropdown-menu {
	opacity: 0;
	transform: translateY(8px);
	transition: transform .18s ease, opacity .18s ease;
}
.dropdown-menu.show, .dropdown.show > .dropdown-menu {
	opacity: 1;
	transform: none;
}
.dropdown-toggle::after { transition: transform .18s ease; }
.dropdown.show > .dropdown-toggle::after { transform: rotate(180deg); }

/* Stronger underline indicator for active links */
.nav-modern .nav-underline .nav-link {
	position: relative;
}
.nav-modern .nav-underline .nav-link::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: -6px;
	height: 3px;
	width: 0;
	background: linear-gradient(90deg, #0d6efd, #0b72ff);
	border-radius: 2px;
	transition: width .2s ease;
}
.nav-modern .nav-underline .nav-link:hover::after, .nav-modern .nav-underline .nav-link.active::after {
	width: 100%;
}

/* Social links */
.social-links a {
	color: #0b2239;
	font-size: 1.1rem;
	opacity: .8;
	transition: opacity .2s ease, color .2s ease;
}
.social-links a:hover { opacity: 1; color: #0d6efd; }
.social-links-footer a { color: rgba(255,255,255,.6); }
.social-links-footer a:hover { color: #fff; opacity: 1; }

/* Nav search */
.nav-search .form-control { min-width: 260px; }
@media (max-width: 991.98px) { .nav-search .form-control { min-width: 100%; } }


/* Fullscreen carousel */
.carousel-full .carousel-item {
	height: 100vh;
	min-height: 560px;
}
.carousel-full .carousel-item > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.carousel-full .carousel-caption {
	bottom: 20%;
	text-shadow: 0 2px 10px rgba(0,0,0,0.6);
}

.news-card img {
	object-fit: cover;
	height: 180px;
}

/* Overlay for carousel for better text contrast */
.carousel-full .carousel-item::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,0.35), rgba(0,0,0,0.55));
}
.carousel-full .carousel-item > img { position: relative; z-index: 1; }
.carousel-full .carousel-caption { position: absolute; z-index: 2; }

/* Generic page hero */
.page-hero {
	position: relative;
	min-height: 200px;
	background-size: cover;
	background-position: center;
	color: #fff;
	display: flex;
	align-items: center;
}
.page-hero::before {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.55));
}
.page-hero > * { position: relative; z-index: 1; }
[data-bs-theme="dark"] .page-hero::before { background: linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.65)); }

/* Feature cards */
.feature-card {
	background: var(--card-bg, #fff);
	border: 1px solid var(--card-border, rgba(0,0,0,.075));
	border-radius: .75rem;
	transition: transform .25s ease, box-shadow .25s ease, background-color .25s ease, border-color .25s ease;
	will-change: transform, box-shadow;
	transform-style: preserve-3d;
}
.feature-card i {
	font-size: 1.8rem;
	color: var(--card-icon, #0d6efd);
    transform-origin: center;
}
.feature-card p.text-secondary { color: var(--card-text-secondary, #6c757d) !important; }
.feature-card:hover { transform: translateY(-3px); box-shadow: 0 10px 28px rgba(0,0,0,.10); }

/* Subtle 3D tilt on pointer */
#capabilities .feature-card.tilted { transition: transform .06s ease; }

/* Decorative glow on reveal */
#capabilities .feature-card.anim::after {
	content: '';
	position: absolute;
	left: 10%; right: 10%; bottom: -12px; height: 18px;
	background: radial-gradient(50% 50% at 50% 50%, rgba(13,110,253,.25), transparent 70%);
	opacity: 0; filter: blur(6px);
	transition: opacity .6s ease;
}
#capabilities .feature-card.anim.show::after { opacity: .6; }

/* Theme variables */
:root {
	--card-bg: #fff;
	--card-border: rgba(0,0,0,.075);
	--card-icon: #0d6efd;
	--card-text-secondary: #6c757d;
}
[data-bs-theme="dark"] {
	--card-bg: #0f1b2c;
	--card-border: rgba(255,255,255,.08);
	--card-icon: #6aa8ff;
	--card-text-secondary: rgba(255,255,255,.72);
}

/* Staggered reveal animation tied to viewport */
#capabilities .feature-card.anim { opacity: 0; transform: translateY(16px); }
#capabilities .feature-card.anim.show { opacity: 1; transform: none; box-shadow: 0 8px 24px rgba(0,0,0,.04); }

/* Icon animations */
@keyframes icon-pop {
	0% { transform: scale(.6) rotate(-10deg); opacity: 0; }
	60% { transform: scale(1.15) rotate(0deg); opacity: 1; }
	100% { transform: scale(1) rotate(0deg); opacity: 1; }
}
@keyframes icon-wave {
	0% { transform: rotate(0deg); }
	30% { transform: rotate(-8deg); }
	60% { transform: rotate(8deg); }
	100% { transform: rotate(0deg); }
}
#capabilities .feature-card.anim.show i { animation: icon-pop .45s cubic-bezier(.2,.8,.2,1) both; filter: drop-shadow(0 4px 10px rgba(13,110,253,.25)); }
.feature-card:hover i { animation: icon-wave .35s ease; }

/* Stats */
.stats {
	background: linear-gradient(90deg, #0a1a2b, #122b46);
	color: #fff;
}
.stat-value { font-size: 2.2rem; font-weight: 700; }
.stat-label { color: rgba(255,255,255,0.75); }

/* News/Testimonial Cards theme-aware */
[data-bs-theme="dark"] .card.news-card, [data-bs-theme="dark"] .testimonial-card { background: #0f1b2c; border-color: rgba(255,255,255,.08); }
[data-bs-theme="dark"] .card.news-card .card-text { color: rgba(255,255,255,.7); }

/* About page */
.about-hero { position: relative; overflow: hidden; }
.about-hero-bg { position: absolute; inset: 0; background: radial-gradient(110% 70% at 0% 0%, rgba(13,110,253,.12), transparent 40%), radial-gradient(90% 60% at 100% 0%, rgba(0,212,255,.12), transparent 50%); pointer-events: none; }
.about-hero-illustration { height: 200px; border-radius: 12px; background: linear-gradient(135deg, rgba(255,255,255,.15), rgba(255,255,255,.05)); border: 1px solid rgba(255,255,255,.25); backdrop-filter: blur(6px); box-shadow: 0 8px 30px rgba(0,0,0,.08); }
.about-hero-illustration { position: relative; overflow: hidden; }
.about-hero-illustration .plane-sim { position: absolute; left: -20%; top: 55%; transform: translateY(-50%); color: #6aa8ff; font-size: 36px; filter: drop-shadow(0 8px 24px rgba(106,168,255,.45)); }
.about-hero-illustration .plane-sim i { display: inline-block; transform-origin: center; }
.about-hero-illustration .plane-sim.p1 { animation: sim-fly-1 7s ease-in-out infinite; }
.about-hero-illustration .plane-sim.p2 { color: #ffd27c; font-size: 40px; filter: drop-shadow(0 8px 24px rgba(255,210,124,.45)); animation: sim-fly-2 8s ease-in-out -1s infinite; }
.about-hero-illustration .plane-sim.p3 { color: #9ef0ff; font-size: 34px; filter: drop-shadow(0 8px 24px rgba(158,240,255,.45)); animation: sim-fly-3 6.2s ease-in-out -.6s infinite; }
@keyframes sim-fly-1 {
	0% { left: -30%; top: 76%; transform: translateY(-50%) rotate(14deg); opacity: .85; }
	25% { left: 15%; top: 48%; transform: translateY(-50%) rotate(4deg); }
	55% { left: 60%; top: 28%; transform: translateY(-50%) rotate(-10deg); opacity: 1; }
	80% { left: 95%; top: 40%; transform: translateY(-50%) rotate(-2deg); }
	100% { left: 120%; top: 66%; transform: translateY(-50%) rotate(8deg); opacity: .95; }
}
@keyframes sim-fly-2 {
	0% { left: -18%; top: 24%; transform: translateY(-50%) rotate(0deg); opacity: .82; }
	35% { left: 32%; top: 54%; transform: translateY(-50%) rotate(12deg); }
	70% { left: 82%; top: 26%; transform: translateY(-50%) rotate(-12deg); opacity: 1; }
	100% { left: 125%; top: 44%; transform: translateY(-50%) rotate(6deg); opacity: .92; }
}
@keyframes sim-fly-3 {
	0% { left: -26%; top: 72%; transform: translateY(-50%) rotate(10deg); opacity: .84; }
	25% { left: 18%; top: 38%; transform: translateY(-50%) rotate(-6deg); }
	55% { left: 54%; top: 66%; transform: translateY(-50%) rotate(8deg); opacity: 1; }
	85% { left: 96%; top: 34%; transform: translateY(-50%) rotate(-4deg); }
	100% { left: 118%; top: 72%; transform: translateY(-50%) rotate(6deg); opacity: .94; }
}
.about-hero-planes { position: absolute; inset: 0; pointer-events: none; }
.about-hero-planes .plane-icon { position: absolute; width: 18px; height: 18px; background: currentColor; color: #6aa8ff; border-radius: 3px; transform-origin: center; opacity: .85; box-shadow: 0 6px 18px rgba(106,168,255,.35); }
.about-hero-planes .p1 { left: 8%; top: 12%; animation: plane-fly-1 7s ease-in-out infinite; }
.about-hero-planes .p2 { right: 10%; top: 24%; color: #ffd27c; box-shadow: 0 6px 18px rgba(255,210,124,.35); animation: plane-fly-2 8s ease-in-out -1.2s infinite; }
.about-hero-planes .p3 { left: 30%; bottom: 10%; color: #9ef0ff; box-shadow: 0 6px 18px rgba(158,240,255,.35); animation: plane-fly-3 6.5s ease-in-out -.8s infinite; }
@keyframes plane-fly-1 { 0% { transform: translate3d(0,0,0) rotate(0deg); } 50% { transform: translate3d(40px,-16px,0) rotate(-8deg); } 100% { transform: translate3d(0,0,0) rotate(0deg); } }
@keyframes plane-fly-2 { 0% { transform: translate3d(0,0,0) rotate(0deg); } 50% { transform: translate3d(-46px,12px,0) rotate(10deg); } 100% { transform: translate3d(0,0,0) rotate(0deg); } }
@keyframes plane-fly-3 { 0% { transform: translate3d(0,0,0) rotate(0deg); } 50% { transform: translate3d(28px,-20px,0) rotate(-6deg); } 100% { transform: translate3d(0,0,0) rotate(0deg); } }
.about-stats { background: linear-gradient(90deg, #0a1a2b, #122b46); color: #fff; }
.about-stats .stat-val { font-size: 2rem; font-weight: 700; }
.about-stats .stat-lbl { color: rgba(255,255,255,.75); }

/* Partner logos reveal */
.logo-cloud .col { opacity: 0; transform: translateY(10px); transition: opacity .4s ease, transform .4s ease; }
.logo-cloud .col.show { opacity: 1; transform: none; }

/* Partners */
.logo-marquee { position: relative; overflow: hidden; }
.logo-marquee .track { display: flex; gap: 64px; align-items: center; width: max-content; animation: marquee 24s linear infinite; }
.logo-marquee .logo { height: 56px; width: auto; object-fit: contain; filter: grayscale(100%) contrast(1.1) brightness(.92); opacity: .8; transition: opacity .25s ease, filter .25s ease, transform .25s ease; }
.logo-marquee .logo:hover { filter: none; opacity: 1; transform: translateY(-2px); }
[data-bs-theme="dark"] .logo-marquee .logo { opacity: .9; filter: grayscale(100%) contrast(1.05) brightness(1.05); }
/* Ensure hover shows original colors in dark theme as well */
[data-bs-theme="dark"] .logo-marquee .logo:hover { filter: none; opacity: 1; transform: translateY(-2px); }

/* Responsive logo sizing and spacing */
@media (max-width: 992px) {
	.logo-marquee .track { gap: 44px; animation-duration: 20s; }
	.logo-marquee .logo { height: 44px; }
}
@media (max-width: 576px) {
	.logo-marquee .track { gap: 32px; animation-duration: 18s; }
	.logo-marquee .logo { height: 36px; }
}
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* CTA */
.cta-animated { position: relative; overflow: hidden; }
.cta-animated .cta-anim-stage { position: relative; height: 220px; }
.cta-animated .cta-line { position: absolute; top: 50%; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent, #ff2d55 30%, #ff2d55 70%, transparent); opacity: .8; transform: translateY(-50%); }
.cta-animated .cta-squares .sq { position: absolute; width: 72px; height: 72px; background: rgba(220, 20, 60, .6); box-shadow: 0 6px 20px rgba(220,20,60,.35); filter: blur(.2px); }
.cta-animated .cta-squares .s1 { bottom: 12%; right: 12%; animation: cta-sq-float 6s ease-in-out infinite; }
.cta-animated .cta-squares .s2 { top: 10%; right: 4%; width: 84px; height: 84px; animation: cta-sq-float 7s ease-in-out -1.2s infinite; }
.cta-animated .cta-squares .s3 { top: 22%; right: 28%; width: 56px; height: 56px; animation: cta-sq-float 5.5s ease-in-out -.6s infinite; }
.cta-animated .cta-squares .s4 { bottom: 8%; right: 32%; width: 96px; height: 96px; animation: cta-sq-float 7.5s ease-in-out -1.8s infinite; }
.cta-animated .cta-squares .s5 { top: 38%; right: 16%; width: 64px; height: 64px; animation: cta-sq-float 6.5s ease-in-out -.9s infinite; }

@keyframes cta-sq-float {
    0% { transform: translate3d(0, 0, 0) rotate(0deg); opacity: .85; }
    50% { transform: translate3d(-12px, -18px, 0) rotate(6deg); opacity: 1; }
    100% { transform: translate3d(0, 0, 0) rotate(0deg); opacity: .85; }
}

[data-bs-theme="dark"] .cta-animated .cta-line { background: linear-gradient(90deg, transparent, #ff5f7a 30%, #ff5f7a 70%, transparent); }
[data-bs-theme="dark"] .cta-animated .cta-squares .sq { background: rgba(255, 71, 110, .55); box-shadow: 0 6px 20px rgba(255,71,110,.35); }

/* Layered parallax slider */
.parallax-slide {
	position: relative;
	height: 100vh;
	min-height: 560px;
	overflow: hidden;
}
.parallax-slide .layer {
	position: absolute;
	inset: 0;
	will-change: transform;
}
.parallax-slide .layer.bg {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.parallax-slide .layer.overlay {
	background: linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.55));
}
.parallax-slide .layer.deco {
	width: 320px;
	height: 320px;
	border-radius: 50%;
	opacity: .25;
	filter: blur(2px);
}
.parallax-slide .layer.deco-1 { top: 10%; left: -5%; background: radial-gradient(closest-side, #7cc0ff, transparent 70%); }
.parallax-slide .layer.deco-2 { bottom: 0; right: -8%; background: radial-gradient(closest-side, #ffd27c, transparent 70%); }

.parallax-slide .slide-content {
	position: absolute;
	left: 8%;
	bottom: 20%;
	max-width: 720px;
	z-index: 5;
}
.parallax-slide .slide-content .btn { box-shadow: 0 6px 20px rgba(13,110,253,.35); }

/* Slider logo layers */
.parallax-slide .logo-layer {
	position: absolute;
	width: 160px;
	opacity: .9;
	filter: drop-shadow(0 4px 16px rgba(0,0,0,.35));
	user-select: none;
	pointer-events: none;
	z-index: 6;
}
.parallax-slide .logo-kaan { top: 12%; left: 8%; }
.parallax-slide .logo-tusas { bottom: 10%; right: 8%; width: 140px; opacity: .85; }

@media (max-width: 576px) {
	.parallax-slide .logo-layer { width: 120px; }
	.parallax-slide .logo-tusas { width: 100px; }
}

/* Parallax */
.parallax {
	position: relative;
	min-height: 50vh;
	background-attachment: fixed;
	background-size: cover;
	background-position: center;
	display: flex;
	align-items: center;
	color: #fff;
}
.parallax::before {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,0.45);
}
.parallax .content { position: relative; z-index: 1; }

/* Hero static */
.hero-static { position: relative; min-height: 100vh; min-height: 100svh; min-height: 100dvh; min-height: calc(var(--app-dvh, 1vh) * 100); color: #fff; overflow: hidden; }
.hero-static .hero-bg { position: absolute; inset: 0; background-size: cover; background-position: center; filter: brightness(.65); }
.hero-static .hero-deco { position: absolute; border-radius: 8px; opacity: .25; filter: blur(1px); }
.hero-static .hero-deco-1 { top: 14%; right: 12%; width: 160px; height: 160px; background: radial-gradient(closest-side, #ff7c96, transparent 70%); }
.hero-static .hero-deco-2 { bottom: 10%; left: 8%; width: 220px; height: 220px; background: radial-gradient(closest-side, #7cc0ff, transparent 70%); }
.hero-static .container { position: relative; z-index: 2; }
.hero-static .badge { background: rgba(255,255,255,.15) !important; color: #fff !important; border: 1px solid rgba(255,255,255,.25); }
.hero-dark .hero-bg::after { content:''; position:absolute; inset:0; background: radial-gradient(65% 60% at 50% 20%, rgba(0,0,0,.1), rgba(0,0,0,.6)); }
.hero-kicker { letter-spacing: .15em; opacity: .85; }
.hero-headline { letter-spacing: .02em; }

/* Hero text animations */
.hero-animated .hero-anim { opacity: 0; transform: translateY(12px); }
.hero-animated .hero-anim.show { opacity: 1; transform: none; transition: opacity .6s ease, transform .6s ease; }
.hero-animated .hero-anim.delay-0.show { transition-delay: .05s; }
.hero-animated .hero-anim.delay-1.show { transition-delay: .18s; }
.hero-animated .hero-anim.delay-2.show { transition-delay: .3s; }

/* Push hero texts lower */
.hero-static .hero-content { position: relative; top: 8vh; }
@media (min-width: 768px) { .hero-static .hero-content { top: 10vh; } }
@media (min-width: 1200px) { .hero-static .hero-content { top: 14vh; } }

/* Parallax for hero */
.hero-static [data-depth] { will-change: transform; }
.hero-illustration { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; pointer-events: none; }
.hero-illustration .plane-wrap { pointer-events: auto; }
.hero-illustration .plane-wrap { position: relative; width: min(90vw, 1200px); }
.hero-illustration .airbus-plane { width: 100%; height: auto; opacity: .98; filter: drop-shadow(0 8px 40px rgba(0,0,0,.35)); animation: planeFade .8s ease .1s both; }
.hero-illustration .plane-outline { position: absolute; inset: 0; width: 100%; height: 100%; }
.plane-outline.loop .pline, .plane-outline.loop .pengine { animation: outlineDraw 3.2s ease-in-out infinite; }
.plane-outline .pline { stroke: rgba(255,255,255,.78); stroke-dasharray: 1000; stroke-dashoffset: 1000; animation: outlineDraw 3.2s ease-in-out infinite; }
.plane-outline .p1 { animation-delay: .25s; }
.plane-outline .p2 { animation-delay: .35s; }
.plane-outline .pN { animation-delay: .42s; opacity: .9; }
.plane-outline .p3 { animation-delay: .45s; }
.plane-outline .p4 { animation-delay: .55s; }
.plane-outline .p5 { animation-delay: .65s; }
.plane-outline .p6 { animation-delay: .75s; }
.plane-outline .p7 { animation-delay: .85s; }
.plane-outline .p8 { animation-delay: .95s; }
.plane-outline .p9 { animation-delay: 1.05s; opacity: .45; }
/* Engine ring strokes */
.plane-outline .pengine { stroke: rgba(255,255,255,.6); stroke-dasharray: 1000; stroke-dashoffset: 1000; animation: outlineDraw 3.2s ease-in-out infinite .8s; }
@keyframes planeFade { from { opacity: 0; transform: translateY(6px) scale(1.01);} to { opacity: .95; transform: none; } }
@keyframes outlineDraw {
  0% { stroke-dashoffset: 1000; }
  62% { stroke-dashoffset: 0; }
  100% { stroke-dashoffset: 0; }
}

/* Outline debug overlay */
.outline-debug { position: absolute; inset: 0; pointer-events: none; }
.outline-debug .hline, .outline-debug .vline { position: absolute; background: rgba(255,0,0,.35); }
.outline-debug .hline { left: 0; right: 0; top: 50%; height: 1px; }
.outline-debug .vline { top: 0; bottom: 0; left: 50%; width: 1px; }
.outline-debug .coord { position: absolute; bottom: 8px; left: 8px; background: rgba(0,0,0,.4); color: #fff; padding: 2px 6px; border-radius: 4px; font-size: 12px; }

/* Timeline */
.timeline { position: relative; margin-left: 1rem; }
.timeline::before { content: ''; position: absolute; left: 8px; top: 0; bottom: 0; width: 2px; background: rgba(13,110,253,.35); }
.timeline .t-item { position: relative; padding-left: 2rem; margin-bottom: 1rem; }
.timeline .t-dot { position: absolute; left: 2px; top: .25rem; width: 12px; height: 12px; background: #0d6efd; border-radius: 50%; box-shadow: 0 0 0 3px rgba(13,110,253,.2); }
.timeline .t-content { background: #fff; border: 1px solid rgba(0,0,0,.08); border-radius: .5rem; padding: .5rem .75rem; }
[data-bs-theme="dark"] .timeline .t-content { background: #0f1b2c; border-color: rgba(255,255,255,.08); }

/* Rain effect */
.hero-rain { position: absolute; inset: 0; pointer-events: none; background-image:
    linear-gradient(to bottom, rgba(255,255,255,.22) 0 40%, transparent 40% 100%),
    linear-gradient(to bottom, rgba(255,255,255,.12) 0 40%, transparent 40% 100%),
    linear-gradient(to bottom, rgba(255,255,255,.12) 0 40%, transparent 40% 100%),
    linear-gradient(to bottom, rgba(255,255,255,.08) 0 40%, transparent 40% 100%),
    linear-gradient(to bottom, rgba(255,255,255,.08) 0 40%, transparent 40% 100%),
    linear-gradient(to bottom, rgba(255,255,255,.22) 0 40%, transparent 40% 100%),
    linear-gradient(to bottom, rgba(255,255,255,.12) 0 40%, transparent 40% 100%),
    linear-gradient(to bottom, rgba(255,255,255,.08) 0 40%, transparent 40% 100%),
    linear-gradient(to bottom, rgba(255,255,255,.12) 0 40%, transparent 40% 100%);
    background-size: 2px 26px, 2px 20px, 2px 22px, 2px 18px, 2px 24px, 2px 26px, 2px 20px, 2px 18px, 2px 22px;
    background-repeat: repeat-y;
    background-position: 12% 0, 20% 0, 28% 0, 36% 0, 45% 0, 55% 0, 65% 0, 76% 0, 88% 0;
    animation: rainMove 1.6s linear infinite;
    opacity: .12;
}
@keyframes rainMove { from { background-position-y: 0, 0, 0, 0, 0, 0, 0, 0, 0; } to { background-position-y: 26px, 20px, 22px, 18px, 24px, 26px, 20px, 18px, 22px; } }

/* Testimonials */
.testimonial-card {
	background: #fff;
	border: 1px solid rgba(0,0,0,.075);
	border-radius: .75rem;
	padding: 1.25rem;
	height: 100%;
}
.testimonial-card i.bi-quote {
	font-size: 2rem;
	color: #0d6efd;
}

/* Contact card */
.contact-card {
	background: linear-gradient(180deg, rgba(13,110,253,.06), rgba(13,110,253,.03));
	border: 1px solid rgba(13,110,253,.15);
	border-radius: .85rem;
	padding: 1rem 1rem;
	box-shadow: 0 8px 24px rgba(0,0,0,.06);
}
.contact-card .title { font-weight: 600; margin-bottom: .5rem; }
.contact-card .item { display: flex; align-items: flex-start; gap: .75rem; padding: .5rem 0; }
.contact-card .item i { font-size: 1.1rem; color: #0d6efd; margin-top: .15rem; }
.contact-card .item .text { color: #0b2239; }
.contact-card .item .text a { color: #0b2239; text-decoration: none; }
.contact-card .item .text a:hover { color: #0d6efd; text-decoration: underline; }
[data-bs-theme="dark"] .contact-card { background: linear-gradient(180deg, rgba(106,168,255,.08), rgba(106,168,255,.04)); border-color: rgba(106,168,255,.25); }
[data-bs-theme="dark"] .contact-card .item .text { color: rgba(255,255,255,.9); }

/* Modal slideout helper */
.modal.modal-dialog-slideout .modal-dialog { position: fixed; margin: auto; right: 0; top: 0; bottom: 0; }
.modal.modal-dialog-slideout .modal-content { height: 100vh; border: 0; border-radius: 0; }
.modal.modal-dialog-slideout .modal-dialog { transform: translateX(100%); transition: transform .25s ease; }
.modal.show.modal-dialog-slideout .modal-dialog { transform: translateX(0); }

