@font-face {
	font-family: 'Manrope-Re';
	src: url("../fonts/Manrope-Regular.ttf") format("truetype");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: 'Manrope-SemiBold';
	src: url("../fonts/Manrope-SemiBold.ttf") format("truetype");
	font-weight: 600;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: 'Manrope-Bold';
	src: url("../fonts/Manrope-Bold.ttf") format("truetype");
	font-weight: 700;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: 'Manrope-Extra';
	src: url("../fonts/Manrope-ExtraBold.ttf") format("truetype");
	font-weight: 800 900;
	font-style: normal;
	font-display: swap;
}
* {
	box-sizing: border-box;
}
html {
	scroll-behavior: smooth;
	scroll-snap-type: none !important;
	background: var(--npn-bg, #020817);
}
body.npn-site-body {
	margin: 0;
	background: var(--npn-bg, #020817);
	color: #eef6ff;
	font-family: 'Manrope-Re';
	overflow-x: hidden;
}
body.npn-site-body a {
	color: inherit;
	text-decoration: none;
}
.npn-home-shell {
	min-height: 100vh;
	background:
		radial-gradient(
			circle at 18% 5%,
			rgba(59, 130, 246, 0.18),
			transparent 26%
		),
		radial-gradient(
			circle at 90% 18%,
			rgba(8, 213, 255, 0.12),
			transparent 24%
		),
		linear-gradient(180deg, #08101f 0%, #060b18 100%);
}
.npn-home-block {
	min-height: 100vh;
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	position: relative;
	overflow: hidden;
}
/* .npn-home-block:before {
	content: "";
	position: absolute;
	inset: auto -18% -35% -18%;
	height: 50%;
	background: radial-gradient(circle, rgba(8, 213, 255, 0.13), transparent 55%);
	pointer-events: none;
	filter: blur(10px);
} */
.npn-home-inner {
	margin: 0 auto;
	position: relative;
	z-index: 2;
}
#home .npn-home-inner {
	width: 100%;
}
.npn-featured-block .npn-home-inner,
.npn-footer-block .npn-home-inner{
	width: 1180px;
}
.row-box {
	border-bottom: 1px solid #26325f;
	width: 100%;
}
.npn-box-ft {
	width: 1180px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
}
/* =========================================================
   HEADER NAV - SVG ARROW / GLOW HOVER / ACTIVE
   Dùng đúng HTML hiện tại:
   .npn-nav > a
   .npn-nav-parent > button
   .npn-submenu
========================================================= */

.npn-header {
	position: sticky;
	top: 0;
	z-index: 100;
    max-width: 1180px;
	min-height: 73px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 26px;
	margin: 0 auto;
}

.npn-logo-mark {
	width: 14px;
	height: 14px;
	border-radius: 999px;
	display: inline-block;
	background: linear-gradient(135deg, #6ee7ff, #7c72ff);
	box-shadow: 0 0 18px rgba(103, 232, 255, 0.82);
}

.npn-nav {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	flex: 1 1 auto;
	min-width: 0;
}

.npn-nav > a,
.npn-nav-parent > button {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 44px;
	padding: 0 16px;
	border-radius: 999px;
	border: 1px solid transparent;
	background: transparent;
	color: #ffffff;
	text-decoration: none;
	font-family: inherit;
	font-size: 15px;
	font-weight: 800;
	line-height: 1;
	white-space: nowrap;
	cursor: pointer;
	transition:
		color 0.24s ease,
		background 0.24s ease,
		border-color 0.24s ease,
		box-shadow 0.24s ease,
		text-shadow 0.24s ease,
		transform 0.24s ease;
}

.npn-nav > a:hover,
.npn-nav-parent:hover > button,
.npn-nav-parent > button:hover {
	color: #76f0ff;
	background:
		radial-gradient(circle at 50% 0%, rgba(108, 239, 255, 0.22), transparent 62%),
		linear-gradient(180deg, rgba(30, 132, 255, 0.22), rgba(2, 18, 54, 0.38));
	border-color: rgba(112, 232, 255, 0.42);
	box-shadow:
		inset 0 0 0 1px rgba(124, 232, 255, 0.12),
		0 0 16px rgba(0, 226, 255, 0.28),
		0 0 36px rgba(0, 133, 255, 0.22);
	text-shadow: 0 0 12px rgba(112, 239, 255, 0.58);
	transform: translateY(-1px);
}
/* =========================================================
   HEADER ACTIVE FIX
   Active trang hiện tại khác với menu cha có submenu
========================================================= */

/* Reset menu cha có submenu: không tự sáng chỉ vì có children */
.npn-nav-parent > button {
	background: transparent;
	border-color: transparent;
	box-shadow: none;
	text-shadow: none;
	color: #ffffff;
}

/* Active thật: chỉ áp dụng cho link trực tiếp đang là trang hiện tại */
.npn-nav > a.is-active {
	color: #76f0ff;
	background:
		radial-gradient(circle at 50% 0%, rgba(108, 239, 255, 0.25), transparent 62%),
		linear-gradient(180deg, rgba(30, 132, 255, 0.27), rgba(2, 18, 54, 0.42));
	border-color: rgba(112, 232, 255, 0.48);
	box-shadow:
		inset 0 0 0 1px rgba(124, 232, 255, 0.14),
		0 0 18px rgba(0, 226, 255, 0.32),
		0 0 42px rgba(0, 133, 255, 0.25);
	text-shadow: 0 0 14px rgba(112, 239, 255, 0.62);
}

/* Hover/open thì menu cha mới sáng */
.npn-nav-parent:hover > button,
.npn-nav-parent.is-open > button,
.npn-nav-parent > button:hover {
	color: #76f0ff;
	background:
		radial-gradient(circle at 50% 0%, rgba(108, 239, 255, 0.22), transparent 62%),
		linear-gradient(180deg, rgba(30, 132, 255, 0.22), rgba(2, 18, 54, 0.38));
	border-color: rgba(112, 232, 255, 0.42);
	box-shadow:
		inset 0 0 0 1px rgba(124, 232, 255, 0.12),
		0 0 16px rgba(0, 226, 255, 0.28),
		0 0 36px rgba(0, 133, 255, 0.22);
	text-shadow: 0 0 12px rgba(112, 239, 255, 0.58);
	transform: translateY(-1px);
}

/* Arrow chỉ xoay khi hover/open/child-active, không xoay chỉ vì parent có submenu */
.npn-nav-parent:hover .npn-menu-arrow svg,
.npn-nav-parent.is-open .npn-menu-arrow svg,
.npn-nav-parent.is-child-active .npn-menu-arrow svg {
	transform: rotate(180deg);
	filter: drop-shadow(0 0 8px rgba(112, 239, 255, 0.9));
}

/* Nếu CSS cũ còn .npn-nav-parent.is-active thì ép nó về bình thường */
.npn-nav-parent.is-active:not(.is-child-active) > button {
	background: transparent !important;
	border-color: transparent !important;
	box-shadow: none !important;
	text-shadow: none !important;
	color: #ffffff !important;
}

/* SVG arrow */
.npn-menu-arrow {
	width: 15px;
	height: 15px;
	flex: 0 0 15px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-left: 1px;
	color: currentColor;
}

.npn-menu-arrow svg {
	width: 100%;
	height: 100%;
	display: block;
	transition:
		transform 0.24s ease,
		filter 0.24s ease,
		opacity 0.24s ease;
}

.npn-nav-parent:hover .npn-menu-arrow svg,
.npn-nav-parent.is-active .npn-menu-arrow svg,
.npn-nav-parent.is-open .npn-menu-arrow svg {
	transform: rotate(180deg);
	filter: drop-shadow(0 0 8px rgba(112, 239, 255, 0.9));
}

/* Parent dropdown */
.npn-nav-parent {
	position: relative;
	display: inline-flex;
	align-items: center;
}

.npn-submenu {
	position: absolute;
	top: calc(100% + 12px);
	left: 50%;
	min-width: 230px;
	padding: 10px;
	border-radius: 18px;
	background: rgba(5, 16, 45, 0.97);
	border: 1px solid rgba(99, 214, 255, 0.22);
	box-shadow:
		0 20px 50px rgba(0, 0, 0, 0.38),
		0 0 24px rgba(0, 178, 255, 0.16);
	backdrop-filter: blur(16px);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translate(-50%, 10px);
	transition:
		opacity 0.24s ease,
		visibility 0.24s ease,
		transform 0.24s ease;
	z-index: 120;
}

.npn-nav-parent:hover .npn-submenu,
.npn-nav-parent.is-open .npn-submenu {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translate(-50%, 0);
}

.npn-submenu::before {
	content: "";
	position: absolute;
	left: 50%;
    top: -8px;
	width: 14px;
	height: 14px;
	background: rgba(5, 16, 45, 0.97);
	border-left: 1px solid rgba(99, 214, 255, 0.22);
	border-top: 1px solid rgba(99, 214, 255, 0.22);
	transform: translateX(-50%) rotate(45deg);
}

.npn-submenu a {
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	min-height: 42px;
	padding: 0 14px;
	border-radius: 12px;
	color: #ffffff;
	text-decoration: none;
	font-size: 14px;
	font-weight: 750;
	white-space: nowrap;
	transition:
		color 0.22s ease,
		background 0.22s ease,
		box-shadow 0.22s ease,
		text-shadow 0.22s ease;
}

.npn-submenu a:hover,
.npn-submenu a.is-active {
	color: #7defff;
	background: rgba(0, 148, 255, 0.15);
	box-shadow:
		inset 0 0 0 1px rgba(112, 231, 255, 0.14),
		0 0 18px rgba(0, 226, 255, 0.12);
	text-shadow: 0 0 10px rgba(112, 239, 255, 0.46);
}

/* Login / Register */
.npn-head-actions {
	display: inline-flex;
	align-items: center;
	justify-content: flex-end;
	flex: 0 0 auto;
}

.npn-login {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 0 18px;
	border-radius: 12px;
	border: 1px solid rgba(112, 232, 255, 0.52);
	background:
		linear-gradient(180deg, rgba(55, 151, 255, 0.95), rgba(18, 91, 210, 0.92));
	color: #ffffff;
	text-decoration: none;
	font-weight: 900;
	box-shadow:
		0 0 18px rgba(0, 226, 255, 0.22),
		inset 0 0 0 1px rgba(255, 255, 255, 0.08);
	transition:
		transform 0.22s ease,
		box-shadow 0.22s ease,
		background 0.22s ease;
}

.npn-login:hover {
	transform: translateY(-1px);
	box-shadow:
		0 0 26px rgba(0, 226, 255, 0.38),
		0 12px 26px rgba(0, 0, 0, 0.22),
		inset 0 0 0 1px rgba(255, 255, 255, 0.12);
}
.npn-nav-parent::after {
	content: "";
	position: absolute;
	left: -8px;
	right: -8px;
	top: 100%;
	height: 16px;
	z-index: 119;
}
/* Profile dot */
.npn-profile-dot {
	width: 44px;
	height: 44px;
	border-radius: 999px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, #6ee7ff, #7c72ff);
	color: #ffffff;
	text-decoration: none;
	font-weight: 900;
	box-shadow: 0 0 20px rgba(103, 232, 255, 0.42);
}

/* Mobile button */
.npn-mobile-menu-toggle {
	display: none;
	width: 44px;
	height: 44px;
	border: 1px solid rgba(112, 232, 255, 0.28);
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.04);
	padding: 0;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 5px;
	cursor: pointer;
}

.npn-mobile-menu-toggle span {
	width: 20px;
	height: 2px;
	border-radius: 999px;
	background: #ffffff;
	box-shadow: 0 0 8px rgba(112, 239, 255, 0.55);
}

/* Responsive */
@media (max-width: 1100px) {
	.npn-header {
		gap: 14px;
	}

	.npn-mobile-menu-toggle {
		display: inline-flex;
		order: 3;
	}

	.npn-head-actions {
		order: 2;
		margin-left: auto;
	}

	.npn-nav {
		position: absolute;
		left: 18px;
		right: 18px;
		top: calc(100% + 10px);
		display: none;
		flex-direction: column;
		align-items: stretch;
		gap: 8px;
		padding: 14px;
		border-radius: 20px;
		background: rgba(5, 16, 45, 0.98);
		border: 1px solid rgba(99, 214, 255, 0.22);
		box-shadow: 0 22px 60px rgba(0, 0, 0, 0.38);
		backdrop-filter: blur(16px);
	}

	.npn-header.is-menu-open .npn-nav,
	.npn-nav.is-open {
		display: flex;
	}

	.npn-nav > a,
	.npn-nav-parent > button {
		width: 100%;
		justify-content: space-between;
		border-radius: 14px;
		min-height: 48px;
	}

	.npn-nav-parent {
		display: block;
		width: 100%;
	}

	.npn-submenu {
		position: static;
		display: none;
		min-width: 0;
		margin-top: 8px;
		padding: 8px;
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		transform: none;
		box-shadow: none;
		background: rgba(255, 255, 255, 0.04);
	}

	.npn-submenu::before {
		display: none;
	}

	.npn-nav-parent.is-open .npn-submenu {
		display: block;
		transform: none;
	}
}

@media (max-width: 560px) {
	.npn-header {
		min-height: 68px;
	}

	.npn-logo strong {
		max-width: 150px;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.npn-login {
		min-height: 40px;
		padding: 0 12px;
		font-size: 13px;
	}
}
.npn-logo {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 15px;
	font-weight: 900;
	color: #fff;
	white-space: nowrap;
}
.npn-logo img {
    height: 75px;
    width: 190px;
	object-fit: contain;
	display: block;
}
.npn-logo-mark {
	width: 14px;
	height: 14px;
	border-radius: 50%;
	display: inline-block;
	background: linear-gradient(135deg, #73e5ff, #6d7cff);
	box-shadow: 0 0 22px var(--npn-glow, #08d5ff);
}
.npn-head-actions {
	display: flex;
	align-items: center;
	gap: 12px;
}
.npn-login,
.npn-profile-dot {
	height: 38px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 10px;
	border: 1px solid rgba(103, 232, 249, 0.6);
	background: linear-gradient(135deg, #0ea5e9, #2f5edb);
	padding: 0 16px;
    font-weight: 600;
	color: #fff;
	box-shadow: 0 0 24px rgba(14, 165, 233, 0.22);
}
.npn-profile-dot {
	width: 38px;
	padding: 0;
	border-radius: 50%;
}
.npn-mobile-menu-toggle {
	display: none;
	width: 42px;
	height: 38px;
	border: 1px solid rgba(103, 232, 249, 0.36);
	border-radius: 10px;
	background: transparent;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 5px;
}
.npn-mobile-menu-toggle span {
	width: 20px;
	height: 2px;
	background: #fff;
	border-radius: 4px;
}
.npn-hero-grid {
	display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(420px, 62%);
	gap: 20px;
	max-width: 1180px;
    padding: 52px 0;
	margin: 0 auto;
}
.npn-hero-copy h1 {
	margin-top: 0;
	margin-bottom: 14px;
}
.npn-hero-copy h1 p {
	margin: 0;
	color: #f5f9ff;
	font-size: clamp(30px, 5vw, 54px);
	line-height: 1.1;
	font-weight: 900;
	font-family: 'Manrope-Extra';
}

.npn-hero-benefits {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	margin-top: 20px;
	max-width: 650px;
}

.npn-hero-benefits span {
	position: relative;
	isolation: isolate;
	overflow: hidden;
	min-height: 46px;
	padding: 13px 16px;
	border-radius: 12px;
	border: 1px solid rgba(103, 232, 249, 0.22);
	background:
		linear-gradient(135deg, rgba(22, 35, 69, 0.82), rgba(11, 26, 58, 0.72));
	font-weight: 600;
	color: #fff;
	box-shadow:
		inset 0 0 0 1px rgba(255, 255, 255, 0.025),
		0 10px 24px rgba(0, 0, 0, 0.14);
	transition:
		transform 0.24s cubic-bezier(0.2, 0.8, 0.2, 1),
		border-color 0.24s ease,
		background 0.24s ease,
		box-shadow 0.24s ease,
		color 0.24s ease;
}

.npn-hero-benefits span::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	border-radius: inherit;
	background:
		radial-gradient(circle at 20% 0%, rgba(8, 213, 255, 0.42), transparent 38%),
		linear-gradient(135deg, rgba(14, 165, 233, 0.24), transparent 52%, rgba(47, 94, 219, 0.28));
	opacity: 0;
	transition: opacity 0.24s ease;
}

.npn-hero-benefits span::after {
	content: "";
	position: absolute;
	top: -40%;
	left: -55%;
	width: 42%;
	height: 180%;
	z-index: 1;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(255, 255, 255, 0.34),
		rgba(126, 231, 255, 0.22),
		transparent
	);
	transform: skewX(-18deg) translateX(0);
	opacity: 0;
	pointer-events: none;
	transition:
		transform 0.52s cubic-bezier(0.2, 0.8, 0.2, 1),
		opacity 0.24s ease;
}

.npn-hero-benefits span:hover {
	transform: translateY(-4px) scale(1.018);
	color: #ffffff;
	border-color: rgba(126, 231, 255, 0.72);
	background:
		linear-gradient(135deg, rgba(6, 52, 84, 0.96), rgba(22, 67, 125, 0.88));
	box-shadow:
		0 0 34px rgba(8, 213, 255, 0.38),
		0 16px 34px rgba(0, 0, 0, 0.22),
		inset 0 0 0 1px rgba(255, 255, 255, 0.07);
}

.npn-hero-benefits span:hover::before {
	opacity: 1;
}

.npn-hero-benefits span:hover::after {
	opacity: 1;
	transform: skewX(-18deg) translateX(430%);
}

.npn-hero-benefits span:active {
	transform: translateY(-2px) scale(1.006);
}

.npn-hero-media {
	border: 1px solid rgba(78, 119, 213, 0.62);
    border-radius: 18px;
	background: rgba(24, 44, 94, 0.72);
	box-shadow: 0 0 0 1px rgba(126, 243, 255, 0.22), 0 0 34px rgba(82, 216, 255, 0.58), 0 0 68px rgba(8, 213, 255, 0.32), 0 22px 46px rgba(0, 0, 0, 0.34);
	min-height: 318px;
	height: 370px;
	position: relative;
}
.npn-video-frame {
	height: 370px;
}
.npn-video-placeholder {
	position: relative;
	min-height: 286px;
	border: 1px dashed rgba(117, 176, 255, 0.8);
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	background: rgba(28, 50, 109, 0.7);
}
.npn-video-placeholder img,
.npn-video-placeholder video,
.npn-hero-iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border: 0;
}
.npn-video-placeholder-text {
	position: relative;
	z-index: 2;
	text-align: center;
	padding: 20px;
	color: #eaf3ff;
	display: grid;
	gap: 13px;
	max-width: 520px;
	text-shadow: 0 2px 14px rgba(0, 0, 0, 0.35);
}
.npn-video-placeholder-text strong {
	font-size: 20px;
}
.npn-video-placeholder-text span {
	line-height: 1.55;
}
.npn-video-placeholder-text small {
	color: #bdd6ff;
}
/* Hero play button - center SVG */
.npn-hero-play {
	position: absolute;
	left: 50%;
	top: 50%;
	z-index: 8;
	width: 78px;
	height: 78px;
	padding: 0;
	border: 0;
	border-radius: 999px;
	background: transparent;
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transform: translate(-50%, -50%);
	cursor: pointer;
	transition: transform 0.22s ease, filter 0.22s ease;
}

.npn-hero-play svg {
	width: 78px;
	height: 78px;
	display: block;
	overflow: visible;
	filter:
		drop-shadow(0 0 18px rgba(8, 213, 255, 0.75))
		drop-shadow(0 12px 24px rgba(0, 0, 0, 0.32));
}

.npn-hero-play svg circle {
	fill: rgba(2, 20, 48, 0.82);
	stroke: rgba(84, 222, 255, 0.95);
	stroke-width: 2;
}

.npn-hero-play svg path {
	fill: #ffffff;
	transform-origin: center;
}

.npn-hero-play:hover {
	transform: translate(-50%, -50%) scale(1.06);
	filter: brightness(1.08);
}

.npn-hero-play:active {
	transform: translate(-50%, -50%) scale(0.98);
}
.npn-try-upload {
	padding-bottom: 48px;
	position: relative;
	z-index: 4;
	margin: 0 auto;
	max-width: 1180px;
}
.npn-try-upload h2,
.npn-section-head-left h2,
.npn-diy-section h2 {
	font-size: 30px;
	line-height: 1.15;
	margin: 0 0 14px;
	color: #fff;
	font-family: 'Manrope-Extra';
	font-weight: 900;
	letter-spacing: -0.03em;
}
.npn-diy-section h2,
.npn-section-head-left h2,
.npn-diy-section > p{
	text-align: center;
}
.npn-try-upload p,
.npn-section-head-left p,
.npn-diy-section > p {
	color: #cbe2ff;
	margin: 0 0 14px;
	line-height: 1.6;
}

.npn-upload-redirect {
	position: relative;
	isolation: isolate;
	overflow: hidden;
	min-height: 150px;
	border-radius: 16px;
	background: rgba(6, 31, 52, 0.82);
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	color: #fff;
	box-shadow:
		0 0 28px rgba(8, 213, 255, 0.12),
		0 14px 34px rgba(0, 0, 0, 0.18);
	transition:
		transform 0.24s ease,
		box-shadow 0.24s ease,
		background 0.24s ease;
}

/* Đường viền chạy quanh box */
.npn-upload-redirect::before {
	content: "";
	position: absolute;
	width: 155%;
	height: 260%;
	left: 50%;
	top: 50%;
	z-index: 0;
	background: conic-gradient(
		from 0deg,
		transparent 0deg,
		transparent 58deg,
		rgba(82, 216, 255, 0.95) 88deg,
		rgba(255, 255, 255, 1) 105deg,
		rgba(126, 243, 255, 0.98) 124deg,
		rgba(47, 94, 219, 0.85) 158deg,
		transparent 210deg,
		transparent 360deg
	);
	transform: translate(-50%, -50%) rotate(0deg);
	animation: npnUploadBorderRotate 3.4s linear infinite;
}

/* Lớp che phần xoay ở giữa, chỉ chừa lại viền */
.npn-upload-redirect::after {
	content: "";
	position: absolute;
	inset: 3px;
	z-index: 1;
	border-radius: 13px;
	background:
		radial-gradient(circle at 22% 0%, rgba(8, 213, 255, 0.12), transparent 38%),
		linear-gradient(135deg, rgba(6, 31, 52, 0.98), rgba(8, 44, 72, 0.94));
	box-shadow:
		inset 0 0 0 1px rgba(255, 255, 255, 0.035),
		inset 0 0 24px rgba(8, 213, 255, 0.06);
}

/* Nội dung nằm trên lớp che */
.npn-upload-content,
.npn-upload-redirect strong,
.npn-upload-redirect em,
.npn-upload-redirect span {
	position: relative;
	z-index: 2;
}

.npn-upload-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 20px;
}

.npn-upload-redirect strong {
	font-size: 20px;
	font-weight: 900;
	color: #ffffff;
	text-shadow:
		0 0 14px rgba(82, 216, 255, 0.42),
		0 0 24px rgba(8, 213, 255, 0.18);
}

.npn-upload-redirect em,
.npn-upload-redirect span {
	font-style: normal;
	color: #d7eaff;
	font-size: 15px;
}

.npn-upload-redirect,
.npn-upload-redirect.is-dragover {
	background: rgba(8, 44, 72, 0.96);
	box-shadow:
		0 0 0 1px rgba(126, 243, 255, 0.22),
		0 0 34px rgba(82, 216, 255, 0.58),
		0 0 68px rgba(8, 213, 255, 0.32),
		0 22px 46px rgba(0, 0, 0, 0.34);
}

.npn-upload-redirect::before,
.npn-upload-redirect.is-dragover::before {
	animation-duration: 1.8/* =========================================================
   Hero title typing gradient effect - fixed height + inline cursor
========================================================= */

.npn-hero-title {
	position: relative;
	display: block;
	margin: 0 0 14px;
	font-family: 'Manrope-Extra', Arial, sans-serif;
	font-weight: 900;
	line-height: 1.02;
	letter-spacing: -0.055em;

	/* Chừa sẵn khoảng trống cho 2 dòng tiêu đề */
	min-height: calc(clamp(40px, 5.2vw, 76px) * 2.08);
}

.npn-hero-title p {
	margin: 0;
	padding: 0;
	font-size: clamp(40px, 5.2vw, 76px);
	line-height: 1.02;
	font-weight: 900;

	background:
		linear-gradient(
			90deg,
			#52d8ff 0%,
			#7ef3ff 22%,
			#6aa7ff 52%,
			#9aa7ff 78%,
			#ffffff 100%
		);
	background-size: 220% 100%;
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	-webkit-text-fill-color: transparent;

	text-shadow:
		0 0 22px rgba(82, 216, 255, 0.26),
		0 0 46px rgba(8, 213, 255, 0.13);

	animation: npnHeroTitleGradient 4.8s ease-in-out infinite;
}

.npn-hero-title .npn-typing-line {
	display: block;
	white-space: nowrap;
}

/* Dấu nháy nằm sát ngay sau chữ đang gõ */
.npn-hero-title .npn-typing-cursor {
	display: inline-block;
	width: 4px;
	height: 0.82em;
	margin-left: 8px;
	border-radius: 999px;
	background: #7ef3ff;
	box-shadow:
		0 0 10px rgba(126, 243, 255, 0.95),
		0 0 22px rgba(8, 213, 255, 0.55);
	vertical-align: -0.04em;
	animation: npnHeroTypingCursor 0.78s steps(2, start) infinite;
}

@keyframes npnHeroTitleGradient {
	0% {
		background-position: 0% 50%;
	}

	50% {
		background-position: 100% 50%;
	}

	100% {
		background-position: 0% 50%;
	}
}

@keyframes npnHeroTypingCursor {
	0%,
	45% {
		opacity: 1;
	}

	46%,
	100% {
		opacity: 0;
	}
}

@media (max-width: 640px) {
	.npn-hero-title {
		min-height: calc(clamp(38px, 13vw, 58px) * 2.1);
		letter-spacing: -0.045em;
	}

	.npn-hero-title p {
		font-size: clamp(38px, 13vw, 58px);
	}

	.npn-hero-title .npn-typing-cursor {
		width: 3px;
		margin-left: 6px;
	}
}s;
	background: conic-gradient(
		from 0deg,
		transparent 0deg,
		transparent 34deg,
		rgba(82, 216, 255, 1) 72deg,
		rgba(255, 255, 255, 1) 98deg,
		rgba(126, 243, 255, 1) 126deg,
		rgba(47, 94, 219, 1) 172deg,
		transparent 238deg,
		transparent 360deg
	);
	filter:
		drop-shadow(0 0 8px rgba(255, 255, 255, 0.75))
		drop-shadow(0 0 18px rgba(82, 216, 255, 0.9));
}

.npn-upload-redirect:hover::after,
.npn-upload-redirect.is-dragover::after {
	background:
		radial-gradient(circle at 22% 0%, rgba(126, 243, 255, 0.22), transparent 42%),
		linear-gradient(135deg, rgba(7, 50, 82, 0.98), rgba(12, 73, 112, 0.96));
	box-shadow:
		inset 0 0 0 1px rgba(126, 243, 255, 0.14),
		inset 0 0 34px rgba(8, 213, 255, 0.16);
}

.npn-upload-redirect strong,
.npn-upload-redirect.is-dragover strong {
	color: #ffffff;
	text-shadow:
		0 0 10px rgba(255, 255, 255, 0.65),
		0 0 22px rgba(82, 216, 255, 0.75),
		0 0 38px rgba(8, 213, 255, 0.42);
}

.npn-upload-redirect span,
.npn-upload-redirect em,
.npn-upload-redirect.is-dragover span,
.npn-upload-redirect.is-dragover em {
	color: #eaffff;
}

@keyframes npnUploadBorderRotate {
	to {
		transform: translate(-50%, -50%) rotate(360deg);
	}
}

.npn-upload-redirect strong {
	font-size: 20px;
}
.npn-upload-redirect span {
	color: #d7eaff;
}
.npn-featured-block {
	align-items: center;
	padding: 34px 0;
}

.npn-section-head-left {
	margin-bottom: 18px;
}

.npn-section-head-left small {
	display: block;
	color: #8db3df;
	font-weight: 700;
	margin-top: 8px;
}

.npn-service-tabs {
	border: 1px solid rgba(80, 116, 202, 0.6);
	border-radius: 14px;
	background: rgba(22, 35, 69, 0.72);
	overflow: hidden;
	box-shadow: 0 0 30px rgba(25, 75, 180, 0.12);
}

.npn-tab-list {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	padding: 12px 14px 10px;
	background: #070c1b;
}

.npn-tab-list button {
	height: 32px;
	border-radius: 999px;
	border: 1px solid rgba(80, 128, 230, 0.75);
	background: #111c38;
	color: #e9f3ff;
	padding: 0 14px;
	font-family: 'Manrope-Re' !important;
	font-weight: 800;
	cursor: pointer;
	transition: all .22s ease;
}

.npn-tab-list button:hover,
.npn-tab-list button.is-active {
	background: linear-gradient(135deg, #0ea5e9, #1d4ed8);
	border-color: #67e8f9;
	color: #fff;
	box-shadow: 0 0 18px rgba(8, 213, 255, 0.28);
}

.npn-tab-stage {
	position: relative;
}

.npn-tab-panel {
	display: none;
	position: relative;
	background: linear-gradient(135deg, rgba(20, 34, 72, 0.9), rgba(29, 43, 86, 0.94));
}

.npn-tab-panel.is-active {
	display: block;
}

.npn-tab-panel-top {
	height: 56px;
	border-top: 1px solid rgba(80, 116, 202, 0.5);
	border-bottom: 1px solid rgba(80, 116, 202, 0.5);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	padding: 0 14px;
	color: #cde5ff;
}

.npn-tab-panel-top span {
	font-weight: 800;
}

.npn-tab-panel-top em {
	font-style: normal;
	color: rgba(203, 229, 255, .65);
	margin: 0 5px;
}

.npn-tab-panel-top b {
	color: #fff;
}

.npn-slide-pause {
	height: 36px;
	border: 1px solid rgba(124, 155, 240, 0.55);
	border-radius: 9px;
	background: #253d86;
	color: #fff;
	font-weight: 900;
	padding: 0 16px;
	display: none;
	font-family: 'Manrope-Re' !important;
	cursor: pointer;
	transition: all .22s ease;
}

.npn-slide-pause:hover {
	background: #3450a6;
	box-shadow: 0 0 20px rgba(8, 213, 255, 0.20);
}

.npn-slide-pause.is-paused {
	background: #ffd000;
	color: #07152b;
	border-color: #ffd000;
}

.npn-service-swiper-wrap {
	position: relative;
	width: 100%;
}

.npn-service-swiper {
	position: relative;
	width: 100%;
	height: auto !important;
	min-height: 0 !important;
	overflow: hidden;
	background: #132552;
}

.npn-service-swiper .swiper-wrapper,
.npn-service-swiper .swiper-slide {
	width: 100%;
	height: 100%;
}

.npn-service-slide-card {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
	overflow: hidden;
	background: #132552;
}

.npn-service-slide-card img {
	display: block;
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	object-fit: cover !important;
	object-position: center center;
	border: 0 !important;
	border-radius: 0 !important;
	margin: 0 !important;
	transition: all 0.3s ease-in;
}

.npn-service-slide-card img:hover {
	box-shadow: 0 0 0 1px rgba(126, 243, 255, 0.22), 0 0 34px rgba(82, 216, 255, 0.58), 0 0 68px rgba(8, 213, 255, 0.32), 0 22px 46px rgba(0, 0, 0, 0.34);
	transition: all 0.3s ease-in;
}

.npn-service-placeholder {
	width: 100%;
	height: 100%;
	min-height: 360px;
	text-align: center;
	color: #fff;
	display: grid;
	place-content: center;
	gap: 9px;
	padding: 30px;
}

.npn-service-placeholder strong {
	font-size: 22px;
}

.npn-service-placeholder span {
	color: #d4e5ff;
}

.npn-service-placeholder small {
	color: #b4cff5;
}

.npn-service-nav {
	position: absolute;
	top: 50%;
	z-index: 10;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	border: 1px solid rgba(103, 232, 249, 0.72);
	background: rgba(7, 23, 46, 0.9);
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: 0 0 20px rgba(8, 213, 255, 0.22);
	transform: translateY(-50%);
	transition: all .22s ease;
}

.npn-service-nav svg {
	width: 24px;
	height: 24px;
	display: block;
}

.npn-service-nav:hover {
	transform: translateY(-50%) scale(1.06);
	background: rgba(7, 35, 70, 0.96);
	box-shadow: 0 0 30px rgba(8, 213, 255, 0.46);
}

.npn-service-prev {
	left: 18px;
}

.npn-service-next {
	right: 18px;
}

.npn-service-nav.swiper-button-disabled {
	opacity: .35;
	cursor: default;
	transform: translateY(-50%);
}

.npn-footer-block {
	padding: 58px 0 0;
	align-items: center;
}
.npn-diy-section {
	margin-bottom: 34px;
}
.npn-diy-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 12px;
}
.npn-diy-card {
	min-height: 150px;
	border: 1px solid rgba(80, 116, 202, 0.62);
	border-radius: 10px;
	background: rgba(20, 31, 61, 0.78);
	padding: 22px 14px 20px;
	cursor: pointer;
	transition: all 0.3s ease-in;
}
.npn-diy-card:hover {
	background: linear-gradient(135deg, #0ea5e9, #1d4ed8);
    border-color: #67e8f9;
    box-shadow: 0 0 18px rgba(8, 213, 255, 0.28);
	transition: all 0.3s ease-in;
}
.npn-diy-card h3 {
	margin: 0 0 18px;
	font-size: 18px;
	color: #fff;
}
.npn-diy-card p {
	margin: 0 0 18px;
	color: #d7e9ff;
	line-height: 1.45;
}
.npn-diy-card span {
	color: #ffd000;
	font-size: 12px;
	font-weight: 900;
}
.npn-about-cta-wrap {
	display: grid;
	gap: 30px;
	text-align: center;
	margin: 28px auto 38px;
	max-width: 820px;
}
.npn-about h2 {
	margin: 0 0 16px;
	font-size: 26px;
}
.npn-about-text,
.npn-cta-text {
	color: #cddcf5;
	line-height: 1.7;
}
.npn-cta {
	display: grid;
	justify-items: center;
	gap: 12px;
}
.npn-cta-icon {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	display: grid;
	place-items: center;
	background: #08d5ff;
	color: #06162b;
	box-shadow: 0 0 26px rgba(8, 213, 255, 0.55);
}
.npn-cta h3 {
	margin: 0;
	font-size: 22px;
}
.npn-cta a {
	height: 44px;
	border-radius: 6px;
	background: #0d6efd;
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0 22px;
	font-weight: 800;
}
.npn-footer {
	border-top: 1px solid rgba(80, 116, 202, 0.6);
    padding: 20px 0;
	display: flex;
	width: 100%;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	color: #fff;
}
.npn-footer p {
	margin: 0 !important;
}
.npn-footer-links {
	display: flex;
	align-items: center;
	gap: 6px;
	flex-wrap: wrap;
}
.npn-footer-links a {
	color: #67e8f9;
	text-decoration: none;
}
.npn-footer-links a:not(:last-child):after {
	content: " · ";
	color: #fff;
	margin-left: 6px;
}

.npn-footer-links a:hover {
	text-shadow: 0 0 14px rgba(112, 239, 255, 0.62);
	color: #76f0ff;
}

/* =========================
Contact floating menu
========================= */
.npn-contact-float {
	position: fixed;
	right: 34px;
	bottom: 34px;
	z-index: 80;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 14px;
}

.npn-contact-toggle {
	width: 62px;
	height: 62px;
	border: 0;
	border-radius: 999px;
	background: radial-gradient(circle at 30% 25%, #89f5ff 0%, #67d9e9 42%, #2898bd 100%);
	color: #fff;
	display: grid;
	place-items: center;
	cursor: pointer;
	box-shadow: 0 0 18px rgba(107, 214, 230, 0.9), 0 0 38px rgba(107, 214, 230, 0.36);
	transition: transform .25s ease, box-shadow .25s ease;
}

.npn-contact-toggle:hover {
	transform: translateY(-2px) scale(1.04);
	box-shadow: 0 0 24px rgba(107, 214, 230, 0.95), 0 0 56px rgba(107, 214, 230, 0.48);
}

.npn-contact-toggle svg {
	display: block;
}

.npn-contact-icon-close,
.npn-contact-float.is-open .npn-contact-icon-open {
	display: none;
}

.npn-contact-float.is-open .npn-contact-icon-close {
	display: grid;
}

.npn-contact-menu {
	min-width: 260px;
	max-width: 320px;
	display: grid;
	gap: 10px;
	opacity: 0;
	visibility: hidden;
	transform: translateY(18px) scale(.94);
	transform-origin: right bottom;
	pointer-events: none;
	transition: opacity .24s ease, visibility .24s ease, transform .24s ease;
}

.npn-contact-float.is-open .npn-contact-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0) scale(1);
	pointer-events: auto;
}

.npn-contact-menu a {
	display: flex;
	align-items: center;
	gap: 11px;
	padding: 12px 14px;
	border-radius: 16px;
	background: rgba(2, 14, 32, 0.92);
	border: 1px solid rgba(130, 230, 255, 0.34);
	color: #fff;
	text-decoration: none;
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.26), 0 0 22px rgba(0, 208, 255, 0.12);
	backdrop-filter: blur(12px);
	transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease, color .22s ease;
}

.npn-contact-menu a:hover {
	transform: translateX(-4px);
	border-color: rgba(151, 242, 255, 0.82);
	box-shadow: 0 14px 34px rgba(0, 0, 0, 0.32), 0 0 26px rgba(0, 208, 255, 0.34);
	color: #9ff3ff;
}

.npn-contact-menu a span {
	width: 38px;
	height: 38px;
	border-radius: 999px;
	background:
		radial-gradient(circle at 32% 24%, rgba(146, 244, 255, 0.30), rgba(103, 217, 233, 0.14) 58%, rgba(103, 217, 233, 0.08));
	color: #9fefff;
	display: grid;
	place-items: center;
	flex: 0 0 auto;
	border: 1px solid rgba(130, 230, 255, 0.16);
	box-shadow: inset 0 0 18px rgba(103, 217, 233, 0.08);
}

.npn-contact-menu a span svg {
	display: block;
	width: 20px;
	height: 20px;
}

.npn-contact-menu a:hover span {
	color: #fff;
	background:
		radial-gradient(circle at 32% 24%, rgba(190, 250, 255, 0.42), rgba(103, 217, 233, 0.22) 58%, rgba(103, 217, 233, 0.12));
	box-shadow:
		0 0 18px rgba(103, 217, 233, 0.30),
		inset 0 0 18px rgba(103, 217, 233, 0.10);
}

.npn-contact-menu a strong {
	font-size: 13px;
	line-height: 1.25;
	font-weight: 800;
	word-break: break-word;
}

.npn-member-auth-body {
	min-height: 100vh;
	background: var(--npn-bg, #020817);
	color: #fff;
	font-family: Manrope, Arial, sans-serif;
	margin: 0;
}
.npn-member-auth-page {
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
	background:
		radial-gradient(circle at 20% 0, rgba(8, 213, 255, 0.18), transparent 30%),
		linear-gradient(135deg, #06101f, #080d1d);
}
.npn-member-card {
	width: min(960px, 100%);
	display: grid;
	grid-template-columns: 1fr 440px;
	border: 1px solid rgba(103, 232, 249, 0.2);
	border-radius: 28px;
	overflow: hidden;
	background: rgba(255, 255, 255, 0.05);
	box-shadow: 0 30px 100px rgba(0, 0, 0, 0.38);
}
.npn-member-info {
	padding: 44px;
	background: rgba(255, 255, 255, 0.035);
}
.npn-member-info h1 {
	font-size: 48px;
	line-height: 1;
	margin: 0 0 16px;
}
.npn-member-info p {
	color: #cde0ff;
	line-height: 1.7;
}
.npn-member-form-wrap {
	padding: 38px;
	background: #fff;
	color: #07152b;
}
.npn-member-tabs {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px;
	margin-bottom: 18px;
}
.npn-member-tabs a {
	height: 42px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 900;
	border: 1px solid #dbeafe;
}
.npn-member-tabs a.is-active {
	background: #ffd000;
	color: #111827;
	border-color: #ffd000;
}
.npn-member-field {
	margin-bottom: 14px;
}
.npn-member-field label {
	display: block;
	font-weight: 900;
	margin-bottom: 8px;
}
.npn-member-field input {
	width: 100%;
	height: 50px;
	border: 1px solid #dbe3ef;
	border-radius: 14px;
	padding: 0 14px;
	font-weight: 700;
}
.npn-member-submit {
	width: 100%;
	height: 52px;
	border: 0;
	border-radius: 14px;
	background: #ffd000;
	font-weight: 900;
	cursor: pointer;
}
.npn-member-alert {
	padding: 13px 14px;
	border-radius: 14px;
	font-weight: 800;
	margin-bottom: 14px;
}
.npn-member-alert-danger {
	background: #fef2f2;
	color: #b91c1c;
	border: 1px solid #fecaca;
}
.npn-member-alert-success {
	background: #ecfdf5;
	color: #047857;
	border: 1px solid #bbf7d0;
}
.npn-member-social {
	display: grid;
	gap: 10px;
	margin-top: 14px;
}
.npn-member-social a {
	height: 44px;
	border-radius: 12px;
	border: 1px solid #dbe3ef;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 900;
}
.npn-member-foot {
	margin-top: 16px;
	text-align: center;
}
.npn-member-foot a {
	color: #64748b;
	font-weight: 800;
}
@media (max-width: 980px) {
	html {
		scroll-snap-type: none;
	}
	.npn-featured-block,
	.npn-footer-block .npn-home-inner,
	.npn-footer{
		padding-left: 20px;
		padding-right: 20px;
	}
	.npn-featured-block .npn-home-inner, .npn-footer-block .npn-home-inner {
		width: 100%;
	}
	.npn-home-block {
		min-height: auto;
	}
	.npn-footer-block .npn-home-inner {
		width: 100%;
	}
	.npn-hero-grid {
		grid-template-columns: 1fr;
		min-height: auto;
		padding: 34px 20px 150px;
	}
	.npn-try-upload {
		margin-top: -120px;
		padding: 0 20px;
	}
	.npn-diy-grid {
		grid-template-columns: repeat(2, 1fr);
	}
	.npn-member-card {
		grid-template-columns: 1fr;
	}
	.npn-member-info {
		display: none;
	}
	.npn-nav {
		position: absolute;
		left: 0;
		right: 0;
		top: 70px;
		display: none;
		background: #0d172d;
		border: 1px solid rgba(103, 232, 249, 0.2);
		border-radius: 16px;
		padding: 14px;
		flex-direction: column;
		align-items: stretch;
	}
	.npn-header.is-menu-open .npn-nav {
		display: flex;
	}
	.npn-mobile-menu-toggle {
		display: flex;
	}
	.npn-nav-parent {
		display: block;
	}
	.npn-submenu {
		position: static;
		opacity: 1;
		visibility: visible;
		transform: none;
		margin-top: 8px;
		background: rgba(255, 255, 255, 0.04);
	}
}
@media (max-width: 640px) {
	.npn-home-inner {
		width: min(100% - 28px, var(--npn-container, 1180px));
	}
	.npn-header {
		height: auto;
		min-height: 68px;
		width: 100%;
	}
	.npn-hero-copy h1 {
		font-size: 46px;
	}
	.npn-hero-benefits {
		grid-template-columns: 1fr;
	}
	.npn-hero-media {
		min-height: 260px;
	}
	.npn-video-placeholder {
		min-height: 230px;
	}
	.npn-try-upload {
		padding-bottom: 28px;
	}
	.npn-upload-redirect {
		min-height: 130px;
	}
	.npn-tab-panel {
		min-height: 520px;
	}
	.npn-service-slide-link {
		height: 464px;
		min-height: 464px;
	}
	.npn-diy-grid {
		grid-template-columns: 1fr;
	}
	.npn-contact-float {
		right: 18px;
		bottom: 18px;
	}
	.npn-member-form-wrap {
		padding: 24px;
	}
	.npn-member-card {
		border-radius: 22px;
	}
	.npn-box-ft {
        flex-wrap: wrap;
        flex-direction: column-reverse;
        gap: 10px;
        justify-content: center;
        align-items: center;
	}
	.npn-hero-copy h1 p br {
		display: none;
	}
	.npn-hero-copy h1 {
		margin-bottom: 15px;
	}
	.npn-footer-links {
		justify-content: center;
	}
}
/* =========================
   Hero intro video / image
========================= */

.npn-hero-video-card {
	position: relative;
	width: 100%;
	min-height: 360px;
	border-radius: 22px;
	padding: 18px;
	background: rgba(31, 54, 118, 0.72);
	border: 1px solid rgba(98, 139, 255, 0.55);
	box-shadow:
		0 0 34px rgba(48, 108, 255, 0.2),
		inset 0 0 0 1px rgba(255,255,255,0.03);
	overflow: hidden;
}

.npn-hero-video-card.has-media {
	padding: 18px;
}

.npn-hero-video-card.is-empty {
	display: flex;
	align-items: center;
	justify-content: center;
}

.npn-hero-video-image,
.npn-hero-video-el,
.npn-hero-video-embed iframe {
	width: 100%;
	height: 100%;
	max-height: 370px;
	display: block;
	border-radius: 18px;
	object-fit: cover;
}

.npn-hero-video-embed {
	width: 100%;
	height: 100%;
}

.npn-hero-video-placeholder {
	width: 100%;
	min-height: 320px;
	border-radius: 18px;
	border: 1px dashed rgba(126, 190, 255, 0.78);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 28px;
	color: #eef6ff;
	background: rgba(24, 46, 105, 0.55);
}

.npn-hero-video-placeholder h3 {
	margin: 0 0 14px;
	font-size: 22px;
	font-weight: 900;
	color: #fff;
}

.npn-hero-video-placeholder p {
	max-width: 520px;
	margin: 0 auto 14px;
	font-size: 16px;
	line-height: 1.55;
	color: rgba(238, 246, 255, 0.92);
}

.npn-hero-video-placeholder span {
	font-size: 13px;
	color: rgba(238, 246, 255, 0.78);
}

.npn-hero-video-play {
	position: absolute;
	right: 34px;
	bottom: 34px;
	width: 64px;
	height: 64px;
	border-radius: 999px;
	border: 1px solid rgba(96, 220, 255, 0.8);
	background: rgba(0, 28, 58, 0.88);
	color: #fff;
	font-size: 22px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 0 22px rgba(56, 210, 255, 0.4);
	cursor: pointer;
}

@media (max-width: 768px) {
	.npn-hero-video-card {
		min-height: 260px;
		padding: 12px;
	}
}

/* =========================================================
   SERVICE SWIPER FINAL GUARD
   Chống CSS cũ làm slide bị tụt / dư chiều cao.
========================================================= */
.npn-tab-panel {
	min-height: 0 !important;
}

.npn-service-swiper,
.npn-service-swiper .swiper-wrapper,
.npn-service-swiper .swiper-slide,
.npn-service-slide-card {
	box-sizing: border-box;
}

.npn-service-swiper .swiper-slide {
	display: block;
}

.npn-service-slide-link,
.npn-service-slide {
	display: none !important;
}

@media (max-width: 768px) {

	.npn-tab-panel-top {
		height: auto;
		min-height: 56px;
		flex-wrap: wrap;
		padding: 10px 12px;
	}

	.npn-service-nav {
		width: 42px;
		height: 42px;
	}

	.npn-service-prev {
		left: 12px;
	}

	.npn-service-next {
		right: 12px;
	}
}
/* Custom scrollbar toÃ n frontend */
html {
	scrollbar-width: thin;
	scrollbar-color: rgba(126, 231, 255, 0.75) rgba(2, 16, 38, 0.95);
}

body::-webkit-scrollbar {
	width: 10px;
}

body::-webkit-scrollbar-track {
	background: rgba(2, 16, 38, 0.96);
	border-left: 1px solid rgba(120, 220, 255, 0.08);
}

body::-webkit-scrollbar-thumb {
	background: linear-gradient(
		180deg,
		rgba(130, 240, 255, 0.95),
		rgba(31, 157, 204, 0.9)
	);
	border-radius: 999px;
	border: 2px solid rgba(2, 16, 38, 0.96);
	box-shadow:
		0 0 12px rgba(0, 210, 255, 0.45),
		inset 0 0 8px rgba(255, 255, 255, 0.18);
}

body::-webkit-scrollbar-thumb:hover {
	background: linear-gradient(
		180deg,
		#b7f6ff,
		#28bde8
	);
	box-shadow:
		0 0 18px rgba(0, 210, 255, 0.72),
		inset 0 0 10px rgba(255, 255, 255, 0.26);
}

body::-webkit-scrollbar-corner {
	background: rgba(2, 16, 38, 0.96);
}

/* =========================================================
   FIXED TOP HEADER FINAL
========================================================= */
#home {
	z-index: 99999999999999;
}
.row-box {
	position: fixed !important;
	top: 0;
	left: 0;
	right: 0;
	z-index: 9999;
	width: 100%;
	background: rgba(5, 13, 31, 0.38);
	border-bottom: 1px solid rgba(112, 232, 255, 0.12);
	backdrop-filter: blur(0);
	transition:
		background 0.25s ease,
		box-shadow 0.25s ease,
		border-color 0.25s ease,
		backdrop-filter 0.25s ease;
}

.row-box.is-scrolled {
	background: rgba(5, 13, 31, 0.94);
	border-bottom-color: rgba(112, 232, 255, 0.24);
	backdrop-filter: blur(16px);
	box-shadow:
		0 12px 34px rgba(0, 0, 0, 0.26),
		0 0 24px rgba(8, 213, 255, 0.12);
}

.row-box .npn-header {
	position: relative !important;
	top: auto !important;
	z-index: 2;
	width: min(1180px, calc(100% - 32px));
	max-width: 1180px;
	min-height: 73px;
	margin: 0 auto;
	background: transparent !important;
	border-bottom: 0 !important;
	box-shadow: none !important;
	transition:
		min-height 0.25s ease,
		padding 0.25s ease;
}

.row-box.is-scrolled .npn-header {
	min-height: 66px;
}

.row-box .npn-logo img {
	transition:
		height 0.25s ease,
		width 0.25s ease;
}

/* Chừa khoảng trên cho header fixed */
.npn-hero-block {
	padding-top: 73px;
}

/* Anchor scroll không bị header che */
#home,
#services,
#diy {
	scroll-margin-top: 90px;
}

/* Submenu phải nổi trên fixed header */
.npn-submenu {
	z-index: 10000;
}

/* Mobile */
@media (max-width: 768px) {
	.row-box .npn-header {
		width: min(100% - 24px, 1180px);
		min-height: 68px;
	}

	.row-box.is-scrolled .npn-logo img,
	.npn-logo img{
		height: auto;
        width: 130px;
	}
	

	.npn-hero-block {
		padding-top: 68px;
	}
}
/* =========================
   Contact floating menu - Mobile safe click
========================= */

.npn-contact-float {
	position: fixed;
	right: 34px;
	bottom: 34px;
	z-index: 80;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 14px;

	/* Quan trọng: wrapper không chặn click toàn vùng */
	pointer-events: none;
}

/* Chỉ nút và menu mới nhận click */
.npn-contact-toggle,
.npn-contact-menu {
	pointer-events: auto;
}

.npn-contact-toggle {
	width: 62px;
	height: 62px;
	border: 0;
	border-radius: 999px;
	background: radial-gradient(circle at 30% 25%, #89f5ff 0%, #67d9e9 42%, #2898bd 100%);
	color: #fff;
	display: grid;
	place-items: center;
	cursor: pointer;
	box-shadow: 0 0 18px rgba(107, 214, 230, 0.9), 0 0 38px rgba(107, 214, 230, 0.36);
	transition: transform .25s ease, box-shadow .25s ease;
}

.npn-contact-toggle:hover {
	transform: translateY(-2px) scale(1.04);
	box-shadow: 0 0 24px rgba(107, 214, 230, 0.95), 0 0 56px rgba(107, 214, 230, 0.48);
}

.npn-contact-toggle svg {
	display: block;
}

.npn-contact-icon-close,
.npn-contact-float.is-open .npn-contact-icon-open {
	display: none;
}

.npn-contact-float.is-open .npn-contact-icon-close {
	display: grid;
}

.npn-contact-menu {
	min-width: 260px;
	max-width: 320px;
	display: grid;
	gap: 10px;
	opacity: 0;
	visibility: hidden;
	transform: translateY(18px) scale(.94);
	transform-origin: right bottom;
	pointer-events: none;
	transition: opacity .24s ease, visibility .24s ease, transform .24s ease;
}

.npn-contact-float.is-open .npn-contact-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0) scale(1);
	pointer-events: auto;
}

/* Mobile: thu nhỏ nút, kéo sát góc hơn, không che slide */
@media (max-width: 640px) {
	.npn-contact-float {
		right: 14px;
		bottom: 14px;
		z-index: 70;
		gap: 10px;
	}

	.npn-contact-toggle {
		width: 52px;
		height: 52px;
		box-shadow:
			0 0 14px rgba(107, 214, 230, 0.75),
			0 0 28px rgba(107, 214, 230, 0.28);
	}

	.npn-contact-menu {
		min-width: min(270px, calc(100vw - 28px));
		max-width: calc(100vw - 28px);
	}
}

/* Mobile rất nhỏ */
@media (max-width: 430px) {
	.npn-contact-float {
		right: 12px;
		bottom: 12px;
	}

	.npn-contact-toggle {
		width: 48px;
		height: 48px;
	}
}
/* =========================================================
   MOBILE MENU FULLSCREEN + CLOSE ICON
========================================================= */

@media (max-width: 980px) {
	.row-box {
		z-index: 99999;
	}

	.npn-header {
		position: relative;
	}

	.npn-mobile-menu-toggle {
		position: relative;
		z-index: 100002;
		display: inline-flex;
		width: 42px;
		height: 42px;
		border-radius: 12px;
		border: 1px solid rgba(103, 232, 249, 0.42);
		background: rgba(6, 18, 42, 0.72);
		box-shadow: 0 0 18px rgba(8, 213, 255, 0.14);
		transition: 0.22s ease;
	}

	.npn-mobile-menu-toggle span {
		position: absolute;
		width: 20px;
		height: 2px;
		border-radius: 999px;
		background: #fff;
		transition:
			transform 0.22s ease,
			opacity 0.22s ease,
			top 0.22s ease;
	}

	.npn-mobile-menu-toggle span:nth-child(1) {
		top: 13px;
	}

	.npn-mobile-menu-toggle span:nth-child(2) {
		top: 20px;
	}

	.npn-mobile-menu-toggle span:nth-child(3) {
		top: 27px;
	}

	/* Khi mở menu: hamburger thành X */
	.npn-header.is-menu-open .npn-mobile-menu-toggle {
		background: rgba(8, 213, 255, 0.16);
		border-color: rgba(103, 232, 249, 0.72);
		box-shadow: 0 0 24px rgba(8, 213, 255, 0.32);
	}

	.npn-header.is-menu-open .npn-mobile-menu-toggle span:nth-child(1) {
		top: 20px;
		transform: rotate(45deg);
	}

	.npn-header.is-menu-open .npn-mobile-menu-toggle span:nth-child(2) {
		opacity: 0;
		transform: scaleX(0);
	}

	.npn-header.is-menu-open .npn-mobile-menu-toggle span:nth-child(3) {
		top: 20px;
		transform: rotate(-45deg);
	}

	/* Menu full màn hình */
	.npn-nav {
		position: fixed !important;
		left: 0 !important;
		right: 0 !important;
		top: 0 !important;
		bottom: 0 !important;
		z-index: 100000;
		width: 100vw !important;
		height: 100vh !important;
		height: 100dvh !important;

		display: flex !important;
		flex-direction: column;
		align-items: stretch;
		justify-content: flex-start;
		gap: 10px;

		padding: 92px 20px 28px !important;
		border-radius: 0 !important;
		border: 0 !important;
		background:
			radial-gradient(circle at 15% 0%, rgba(8, 213, 255, 0.16), transparent 32%),
			linear-gradient(180deg, rgba(5, 13, 31, 0.98), rgba(4, 9, 22, 0.99)) !important;
		backdrop-filter: blur(18px);
		box-shadow: none !important;

		opacity: 0;
		visibility: hidden;
		pointer-events: none;
		transform: translateY(-10px);
		transition:
			opacity 0.24s ease,
			visibility 0.24s ease,
			transform 0.24s ease;
		overflow-y: auto;
	}

	.npn-header.is-menu-open .npn-nav,
	.npn-nav.is-open {
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		transform: translateY(0);
	}

	.npn-nav > a,
	.npn-nav-parent > button {
		width: 100%;
		min-height: 58px;
		justify-content: space-between;
		padding: 0 20px;
		border-radius: 16px;
		font-size: 17px;
		font-weight: 900;
		background: rgba(12, 28, 62, 0.62);
		border: 1px solid rgba(103, 232, 249, 0.16);
	}

	.npn-nav > a.is-active {
		background:
			radial-gradient(circle at 50% 0%, rgba(108, 239, 255, 0.22), transparent 62%),
			linear-gradient(180deg, rgba(30, 132, 255, 0.28), rgba(2, 18, 54, 0.5));
		border-color: rgba(112, 232, 255, 0.48);
		box-shadow:
			inset 0 0 0 1px rgba(124, 232, 255, 0.14),
			0 0 22px rgba(0, 226, 255, 0.26);
	}

	.npn-nav-parent {
		width: 100%;
		display: block;
	}

	.npn-submenu {
		position: static !important;
		display: none;
		width: 100%;
		min-width: 0;
		margin: 8px 0 0;
		padding: 8px;
		border-radius: 16px;
		background: rgba(255, 255, 255, 0.045);
		border: 1px solid rgba(103, 232, 249, 0.12);
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		transform: none !important;
		box-shadow: none;
	}

	.npn-submenu::before,
	.npn-nav-parent::after {
		display: none !important;
	}

	.npn-nav-parent.is-open .npn-submenu {
		display: grid;
		gap: 6px;
	}

	.npn-submenu a {
		min-height: 44px;
		padding: 0 16px;
		border-radius: 12px;
		font-size: 15px;
		color: #dbeafe;
		background: rgba(255, 255, 255, 0.035);
	}

	body.npn-mobile-menu-open {
		overflow: hidden;
		touch-action: none;
	}
}
/* =========================================================
   PAGE VERTICAL SWIPER
   Mỗi section là 1 slide full màn hình
========================================================= */

:root {
	--npn-header-h: 73px;
	--npn-container-w: 1180px;
}

html,
body.npn-site-body {
	width: 100%;
	height: 100%;
	overflow: hidden;
	scroll-behavior: auto !important;
	scroll-snap-type: none !important;
}

.npn-home-shell {
	width: 100%;
	height: 100vh;
	height: 100dvh;
	overflow: hidden;
}

.npn-page-swiper {
	width: 100%;
	height: 100vh;
	height: 100dvh;
	overflow: hidden;
}

.npn-page-swiper > .swiper-wrapper {
	width: 100%;
	height: 100%;
}

.npn-page-slide {
	width: 100%;
	height: 100vh !important;
	height: 100dvh !important;
	min-height: 100vh !important;
	min-height: 100dvh !important;
	overflow: hidden !important;
	position: relative;
}

/* Header fixed */
.row-box {
	position: fixed !important;
	top: 0;
	left: 0;
	right: 0;
	z-index: 99999;
	width: 100%;
	background: rgba(5, 13, 31, 0.38);
	border-bottom: 1px solid rgba(112, 232, 255, 0.12);
	transition:
		background 0.25s ease,
		box-shadow 0.25s ease,
		backdrop-filter 0.25s ease,
		border-color 0.25s ease;
}

.row-box.is-scrolled {
	background: rgba(5, 13, 31, 0.94);
	border-bottom-color: rgba(112, 232, 255, 0.24);
	backdrop-filter: blur(16px);
	box-shadow:
		0 12px 34px rgba(0, 0, 0, 0.26),
		0 0 24px rgba(8, 213, 255, 0.12);
}

.row-box .npn-header {
	width: min(var(--npn-container-w), calc(100% - 32px));
	max-width: var(--npn-container-w);
	margin: 0 auto;
}

/* =========================================================
   Slide 1: Hero
========================================================= */

.npn-hero-block {
	padding-top: var(--npn-header-h) !important;
}

.npn-hero-block .npn-home-inner {
	width: 100%;
	height: calc(100dvh - var(--npn-header-h));
	display: flex;
	flex-direction: column;
	justify-content: center;
	overflow: hidden;
}

.npn-try-upload {
	width: min(var(--npn-container-w), calc(100% - 40px));
	margin: 0 auto;
	padding: 0 0 22px !important;
}

/* =========================================================
   Slide 2: Featured Services
========================================================= */

.npn-featured-block {
	padding-top: var(--npn-header-h) !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}

.npn-featured-block .npn-section-head-left {
	flex: 0 0 auto;
	margin: 0 0 16px !important;
	padding: 0 !important;
}

.npn-featured-block .npn-section-head-left p {
	margin: 0 !important;
	line-height: 1.45 !important;
}

.npn-service-tabs {
	flex: 0 0 auto !important;
	width: 100%;
	display: flex !important;
	flex-direction: column !important;
	overflow: hidden !important;
	border-radius: 14px;
}

.npn-tab-list {
	flex: 0 0 auto !important;
	padding: 10px 14px 9px !important;
}

.npn-tab-list button {
	height: 30px !important;
	font-size: 13px !important;
	padding: 0 12px !important;
}

.npn-tab-panel-top {
	flex: 0 0 48px !important;
	height: 48px !important;
	min-height: 48px !important;
}

.npn-tab-stage {
	flex: 0 0 auto !important;
	display: block !important;
	overflow: hidden !important;
}

.npn-tab-panel {
	width: 100% !important;
	min-height: 0 !important;
	overflow: hidden !important;
}

.npn-tab-panel.is-active {
	display: block !important;
}

/* Slide ảnh service vừa khung, không cần 3:2 */
.npn-service-swiper-wrap {
	position: relative;
	width: 100% !important;
	height: clamp(360px, 54vh, 570px) !important;
	overflow: hidden !important;
}

.npn-service-swiper {
	width: 100% !important;
	height: 100% !important;
	min-height: 0 !important;
	aspect-ratio: auto !important;
	overflow: hidden !important;
	background: #132552;
}

.npn-service-swiper .swiper-wrapper,
.npn-service-swiper .swiper-slide,
.npn-service-slide-card {
	width: 100% !important;
	height: 100% !important;
	min-height: 0 !important;
}

/* =========================================================
   Slide 3: DIY + About + CTA + Footer
========================================================= */

.npn-footer-block {
	padding-top: var(--npn-header-h) !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}
.npn-diy-section {
	margin: 0 0 28px !important;
}

.npn-diy-section h2 {
	font-size: 28px !important;
	margin: 0 0 10px !important;
	line-height: 1.15 !important;
}

.npn-diy-section > p {
	margin: 0 0 16px !important;
	line-height: 1.45 !important;
}

.npn-diy-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 12px;
}

.npn-diy-card {
	min-height: 122px !important;
	padding: 18px 14px !important;
}

.npn-diy-card h3 {
	margin: 0 0 10px !important;
	font-size: 17px !important;
}

.npn-diy-card p {
	margin: 0 0 10px !important;
	line-height: 1.4 !important;
}

.npn-about-cta-wrap {
	gap: 18px !important;
	margin: 18px auto 24px !important;
	max-width: 820px;
}

.npn-about h2 {
	margin: 0 0 12px !important;
	font-size: 25px !important;
}

.npn-about-text,
.npn-cta-text {
	line-height: 1.55 !important;
}

.npn-cta {
	gap: 10px !important;
}

.npn-cta h3 {
	font-size: 22px !important;
}

.npn-cta a {
	height: 42px !important;
}

.npn-footer {
	flex: 0 0 auto;
	margin-top: auto;
	padding: 18px 0 !important;
}

/* Màn hình thấp */
@media (max-height: 760px) and (min-width: 981px) {
	.npn-featured-block .npn-section-head-left h2,
	.npn-diy-section h2 {
		font-size: 24px !important;
	}

	.npn-featured-block .npn-section-head-left p,
	.npn-diy-section > p {
		font-size: 14px !important;
	}

	.npn-service-swiper-wrap {
		height: clamp(320px, 50vh, 500px) !important;
	}

	.npn-diy-card {
		min-height: 104px !important;
		padding: 14px 12px !important;
	}

	.npn-diy-card h3 {
		font-size: 16px !important;
		margin-bottom: 7px !important;
	}

	.npn-diy-card p {
		font-size: 14px !important;
		margin-bottom: 7px !important;
	}

	.npn-about-cta-wrap {
		gap: 12px !important;
		margin: 12px auto 16px !important;
	}

	.npn-about h2 {
		font-size: 22px !important;
	}

	.npn-footer {
		padding: 14px 0 !important;
	}
}

/* Mobile: destroy page swiper, scroll thường */
@media (max-width: 980px) {
	html,
	body.npn-site-body {
		height: auto;
		overflow-x: hidden;
		overflow-y: auto;
	}

	.npn-home-shell,
	.npn-page-swiper,
	.npn-page-swiper > .swiper-wrapper,
	.npn-page-slide {
		height: auto !important;
		min-height: auto !important;
		overflow: visible !important;
		display: block !important;
		transform: none !important;
	}

	.npn-hero-block,
	.npn-featured-block,
	.npn-footer-block {
		padding-top: 0 !important;
	}
	.npn-hero-block {
		padding-top: 68px !important;
	}

	.npn-hero-block .npn-home-inner,
	.npn-featured-block .npn-home-inner,
	.npn-footer-block .npn-home-inner {
		width: 100%;
		height: auto !important;
		display: block !important;
		overflow: visible !important;
	}

	.npn-hero-grid {
		width: 100% !important;
		grid-template-columns: 1fr !important;
		padding: 26px 20px 20px !important;
	}

	.npn-try-upload {
		width: 100% !important;
		padding: 30px 20px !important;
	}

	.npn-service-swiper-wrap {
		height: clamp(260px, 62vw, 520px) !important;
	}

	.npn-diy-grid {
		grid-template-columns: 1fr !important;
	}

	.npn-footer {
		margin-top: 24px;
	}
}
/* =========================================================
   Hero title typing gradient effect - fixed height + inline cursor
========================================================= */

.npn-hero-title {
	position: relative;
	display: block;
	margin: 0 0 14px;
	font-family: 'Manrope-Extra', Arial, sans-serif;
	font-weight: 900;
	line-height: 1.02;
	letter-spacing: -0.055em;

	/* Chừa sẵn khoảng trống cho 2 dòng tiêu đề */
	min-height: calc(clamp(40px, 5.2vw, 76px) * 2.08);
}

.npn-hero-title p {
	margin: 0;
	padding: 0;
	font-size: clamp(40px, 5.2vw, 76px);
	line-height: 1.02;
	font-weight: 900;

	background:
		linear-gradient(
			90deg,
			#52d8ff 0%,
			#7ef3ff 22%,
			#6aa7ff 52%,
			#9aa7ff 78%,
			#ffffff 100%
		);
	background-size: 220% 100%;
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	-webkit-text-fill-color: transparent;

	text-shadow:
		0 0 22px rgba(82, 216, 255, 0.26),
		0 0 46px rgba(8, 213, 255, 0.13);

	animation: npnHeroTitleGradient 4.8s ease-in-out infinite;
}

.npn-hero-title .npn-typing-line {
	display: block;
	white-space: nowrap;
}

/* Dấu nháy nằm sát ngay sau chữ đang gõ */
.npn-hero-title .npn-typing-cursor {
	display: inline-block;
	width: 4px;
	height: 0.82em;
	margin-left: 8px;
	border-radius: 999px;
	background: #7ef3ff;
	box-shadow:
		0 0 10px rgba(126, 243, 255, 0.95),
		0 0 22px rgba(8, 213, 255, 0.55);
	vertical-align: -0.04em;
	animation: npnHeroTypingCursor 0.78s steps(2, start) infinite;
}
.npn-hero-copy h1 p:first-child {
	font-size: 60px;
	margin-bottom: 15px;
}
.npn-hero-copy h1 p:last-child {
	font-size: 45px;
}
@keyframes npnHeroTitleGradient {
	0% {
		background-position: 0% 50%;
	}

	50% {
		background-position: 100% 50%;
	}

	100% {
		background-position: 0% 50%;
	}
}

@keyframes npnHeroTypingCursor {
	0%,
	45% {
		opacity: 1;
	}

	46%,
	100% {
		opacity: 0;
	}
}

@media (max-width: 640px) {
	.npn-hero-title {
		min-height: calc(clamp(38px, 13vw, 58px) * 2.1);
		letter-spacing: -0.045em;
	}

	.npn-hero-title p {
		font-size: clamp(38px, 13vw, 58px);
	}

	.npn-hero-title .npn-typing-cursor {
		width: 3px;
		margin-left: 6px;
	}
}

/* =========================================================
   Service image hover - smooth light only, no zoom
========================================================= */

.npn-service-slide-card {
	position: relative;
	overflow: hidden;
	isolation: isolate;
}

/* Lớp sáng phủ nhẹ, chỉ fade opacity */
.npn-service-slide-card::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 2;
	background:
		radial-gradient(circle at 28% 12%, rgba(126, 243, 255, 0.22), transparent 36%),
		linear-gradient(135deg, rgba(8, 213, 255, 0.10), transparent 58%),
		linear-gradient(0deg, rgba(3, 12, 30, 0.04), rgba(255, 255, 255, 0.05));
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.38s ease;
	will-change: opacity;
}

/* Vệt sáng chạy 1 lần khi hover */
.npn-service-slide-card::after {
	content: "";
	position: absolute;
	top: -45%;
	left: -70%;
	z-index: 3;
	width: 36%;
	height: 190%;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(255, 255, 255, 0.24),
		rgba(126, 243, 255, 0.18),
		transparent
	);
	transform: skewX(-18deg) translate3d(0, 0, 0);
	opacity: 0;
	pointer-events: none;
	will-change: transform, opacity;
}

/* Ảnh không zoom, chỉ sáng nhẹ */
.npn-service-slide-card img {
	transform: translate3d(0, 0, 0) !important;
	transition: filter 0.42s ease !important;
	will-change: filter;
}

/* Hover mượt */
.npn-service-slide-card:hover::before {
	opacity: 1;
}

.npn-service-slide-card:hover::after {
	animation: npnServiceImageShineSmooth 0.9s cubic-bezier(0.2, 0.8, 0.2, 1) 1;
}

.npn-service-slide-card:hover img {
	transform: translate3d(0, 0, 0) !important;
	filter: brightness(1.12) contrast(1.05) saturate(1.08);
}

/* Không dùng animation lặp để tránh giật */
@keyframes npnServiceImageShineSmooth {
	0% {
		transform: skewX(-18deg) translate3d(0, 0, 0);
		opacity: 0;
	}

	18% {
		opacity: 1;
	}

	100% {
		transform: skewX(-18deg) translate3d(520%, 0, 0);
		opacity: 0;
	}
}
/* =========================================================
   SMALL LAPTOP CONTENT FIT - SAFE VERSION
   Không đụng swiper-wrapper / swiper-slide để tránh mất section
========================================================= */

@media (min-width: 981px) and (max-width: 1440px) and (max-height: 850px) {

	/* Container nhỏ lại */
	.npn-hero-grid,
	.npn-try-upload,
	.npn-featured-block .npn-home-inner,
	.npn-footer-block .npn-home-inner {
		width: min(1080px, calc(100% - 48px)) !important;
	}

	/* SECTION 1 */
	.npn-hero-block .npn-home-inner {
		display: flex !important;
		flex-direction: column !important;
		justify-content: center !important;
		overflow: hidden !important;
	}

	.npn-hero-grid {
		gap: 14px !important;
		padding: 8px 0 8px !important;
		align-items: center !important;
	}

	.npn-hero-title {
		margin-bottom: 8px !important;
		min-height: calc(clamp(30px, 4.2vw, 54px) * 2.02) !important;
	}

	.npn-hero-title p {
		font-size: clamp(30px, 4.2vw, 54px) !important;
		line-height: 1 !important;
	}

	.npn-hero-subtitle {
		font-size: 14px !important;
		line-height: 1.42 !important;
		margin-top: 6px !important;
		margin-bottom: 10px !important;
		max-width: 520px !important;
	}

	.npn-hero-benefits {
		gap: 8px !important;
		margin-top: 12px !important;
	}
	.npn-hero-video-card,
	.npn-video-placeholder,
	.npn-hero-video-image,
	.npn-hero-video-el,
	.npn-hero-video-embed iframe,
	.npn-hero-video-placeholder {
		height: 100%;
		min-height: 0 !important;
	}

	.npn-try-upload {
		padding-bottom: 8px !important;
	}

	.npn-upload-redirect {
		min-height: 78px !important;
	}

	.npn-upload-redirect strong {
		font-size: 16px !important;
	}

	.npn-upload-redirect span,
	.npn-upload-redirect em {
		font-size: 13px !important;
	}

	/* SECTION 2 */
	.npn-featured-block .npn-home-inner {
		display: flex !important;
		flex-direction: column !important;
		justify-content: center !important;
		overflow: hidden !important;
	}

	.npn-featured-block .npn-section-head-left {
		margin-bottom: 10px !important;
	}

	.npn-featured-block .npn-section-head-left h2 {
		font-size: 24px !important;
		margin-bottom: 5px !important;
	}

	.npn-featured-block .npn-section-head-left p {
		font-size: 14px !important;
		line-height: 1.4 !important;
	}

	.npn-tab-list {
		padding: 8px 12px !important;
		gap: 6px !important;
	}

	.npn-tab-list button {
		height: 28px !important;
		font-size: 12px !important;
		padding: 0 10px !important;
	}

	.npn-tab-panel-top {
		height: 42px !important;
		min-height: 42px !important;
		padding: 0 12px !important;
		font-size: 13px !important;
	}

	.npn-slide-pause {
		height: 32px !important;
		padding: 0 12px !important;
		font-size: 12px !important;
	}

	.npn-service-swiper-wrap {
		height: clamp(280px, 54vh, 470px) !important;
	}

	/* SECTION 3 */
	.npn-footer-block .npn-home-inner {
		display: flex !important;
		flex-direction: column !important;
		justify-content: center !important;
		overflow: hidden !important;
	}

	.npn-diy-section {
		margin-bottom: 12px !important;
	}

	.npn-diy-section h2 {
		font-size: 24px !important;
		margin-bottom: 6px !important;
	}

	.npn-diy-section > p {
		font-size: 14px !important;
		line-height: 1.4 !important;
		margin-bottom: 10px !important;
	}

	.npn-diy-grid {
		gap: 8px !important;
	}

	.npn-diy-card {
		min-height: 88px !important;
		padding: 12px !important;
		border-radius: 9px !important;
	}

	.npn-diy-card h3 {
		font-size: 15px !important;
		margin-bottom: 6px !important;
	}

	.npn-diy-card p {
		font-size: 13px !important;
		line-height: 1.32 !important;
		margin-bottom: 6px !important;
	}

	.npn-diy-card span {
		font-size: 11px !important;
	}

	.npn-about-cta-wrap {
		gap: 10px !important;
		margin: 10px auto 12px !important;
		max-width: 760px !important;
	}

	.npn-about h2 {
		font-size: 21px !important;
		margin-bottom: 6px !important;
	}

	.npn-about-text,
	.npn-cta-text {
		font-size: 13px !important;
		line-height: 1.38 !important;
	}

	.npn-cta {
		gap: 7px !important;
	}

	.npn-cta h3 {
		font-size: 18px !important;
	}

	.npn-cta a {
		height: 36px !important;
		padding: 0 18px !important;
	}

	.npn-footer {
		padding: 10px 0 !important;
		font-size: 13px !important;
	}
}

/* =========================================================
   LENOVO / SMALL LAPTOP HERO FIT FIX
   Fix section 1 bị cắt dưới màn laptop thấp
========================================================= */

@media (min-width: 981px) and (max-width: 1500px) and (max-height: 850px) {
	:root {
		--npn-laptop-header-h: 92px;
	}

	/* Section 1 vẫn đúng 1 khung */
	.npn-hero-block {
		height: 100dvh !important;
		min-height: 100dvh !important;
		overflow: hidden !important;
		padding-top: 0 !important;
	}
	/* Chừa khoảng top cho menu fixed */
	.npn-hero-block .npn-home-inner {
		height: 100dvh !important;
		min-height: 0 !important;
		box-sizing: border-box !important;
		padding-top: var(--npn-laptop-header-h) !important;
		display: flex !important;
		flex-direction: column !important;
		justify-content: center !important;
		overflow: hidden !important;
	}

	/* Hero grid co lại */
	.npn-hero-grid {
		width: min(1120px, calc(100% - 56px)) !important;
		margin: 0 auto !important;
		grid-template-columns: minmax(0, 0.88fr) minmax(420px, 1.12fr) !important;
		gap: 14px !important;
		padding: 0 0 8px !important;
		align-items: center !important;
	}

	/* Tiêu đề co lại để không bị đẩy xuống */
	.npn-hero-title {
		margin-bottom: 6px !important;
		min-height: calc(clamp(34px, 4.3vw, 58px) * 2.02) !important;
	}

	.npn-hero-title p {
		font-size: clamp(34px, 4.3vw, 58px) !important;
		line-height: 0.98 !important;
	}

	.npn-hero-subtitle {
		font-size: 14px !important;
		line-height: 1.38 !important;
		margin-top: 6px !important;
		margin-bottom: 10px !important;
		max-width: 500px !important;
	}

	.npn-hero-benefits {
		gap: 8px !important;
		margin-top: 10px !important;
	}

	.npn-hero-benefits span {
		min-height: 34px !important;
		padding: 8px 10px !important;
		font-size: 12px !important;
		line-height: 1.25 !important;
		border-radius: 9px !important;
	}

	/* Video bên phải co chiều cao */
	.npn-hero-media,
	.npn-video-frame{
		height: 280px;
		min-height: unset !important;
	}

	/* Khối Try upload co lại */
	.npn-try-upload {
		width: min(1120px, calc(100% - 56px)) !important;
		margin: 0 auto !important;
		padding: 0 0 10px !important;
	}

	.npn-try-upload h2 {
		font-size: clamp(24px, 2.4vw, 32px) !important;
		line-height: 1.1 !important;
		margin: 0 0 8px !important;
	}

	.npn-try-upload p {
		font-size: 14px !important;
		line-height: 1.35 !important;
		margin: 0 0 10px !important;
	}

	.npn-upload-redirect {
		min-height: 78px !important;
		border-radius: 14px !important;
	}

	.npn-upload-content {
		padding: 12px 18px !important;
	}

	.npn-upload-redirect strong {
		font-size: 16px !important;
		line-height: 1.25 !important;
	}

	.npn-upload-redirect span,
	.npn-upload-redirect em {
		font-size: 12px !important;
		line-height: 1.25 !important;
	}
}

/* Màn laptop cực thấp hơn nữa */
@media (min-width: 981px) and (max-width: 1500px) and (max-height: 740px) {
	:root {
		--npn-laptop-header-h: 82px;
	}

	.npn-hero-grid {
		width: min(1060px, calc(100% - 60px)) !important;
		grid-template-columns: minmax(0, 0.85fr) minmax(390px, 1fr) !important;
		gap: 12px !important;
		padding-bottom: 6px !important;
	}

	.npn-hero-title {
		min-height: calc(clamp(30px, 4vw, 50px) * 2) !important;
	}

	.npn-hero-title p {
		font-size: clamp(30px, 4vw, 50px) !important;
	}

	.npn-hero-subtitle {
		font-size: 13px !important;
		margin-bottom: 8px !important;
	}

	.npn-hero-benefits {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: 7px !important;
	}

	.npn-hero-benefits span {
		font-size: 11.5px !important;
	}

	.npn-try-upload {
		width: min(1060px, calc(100% - 60px)) !important;
		padding-bottom: 6px !important;
	}

	.npn-try-upload h2 {
		font-size: 24px !important;
		margin-bottom: 5px !important;
	}

	.npn-try-upload p {
		font-size: 13px !important;
		margin-bottom: 7px !important;
	}

	.npn-upload-redirect {
		min-height: 64px !important;
	}

	.npn-upload-redirect strong {
		font-size: 15px !important;
	}

	.npn-upload-redirect span,
	.npn-upload-redirect em {
		font-size: 11.5px !important;
	}
}
/* Cực thấp <= 540px: co thêm, ưu tiên không cắt */
@media (min-width: 981px) and (max-height: 540px) {
	:root {
		--npn-laptop-header-h: 64px;
	}

	.npn-hero-grid {
		width: min(1000px, calc(100% - 70px)) !important;
		grid-template-columns: minmax(0, 0.8fr) minmax(330px, 0.95fr) !important;
		gap: 8px !important;
	}

	.npn-hero-title {
		min-height: calc(clamp(24px, 3.2vw, 36px) * 2) !important;
	}

	.npn-hero-title p {
		font-size: clamp(24px, 3.2vw, 36px) !important;
	}

	.npn-hero-subtitle {
		font-size: 11.5px !important;
		line-height: 1.25 !important;
		margin-bottom: 5px !important;
	}

	.npn-hero-benefits span {
		min-height: 24px !important;
		padding: 5px 7px !important;
		font-size: 10.5px !important;
	}

	.npn-hero-video-card,
	.npn-video-placeholder,
	.npn-hero-video-image,
	.npn-hero-video-el,
	.npn-hero-video-embed iframe,
	.npn-hero-video-placeholder {
		height: clamp(135px, 31vh, 205px) !important;
	}

	.npn-try-upload {
		width: min(1000px, calc(100% - 70px)) !important;
	}

	.npn-try-upload h2 {
		font-size: 18px !important;
	}

	.npn-try-upload p {
		display: none !important;
	}

	.npn-upload-redirect {
		min-height: 44px !important;
	}

	.npn-upload-redirect span,
	.npn-upload-redirect em {
		display: none !important;
	}
}