/* Hero Banner Pattern
---------------------------------------- */

.nou-hero-banner {
	--nou-hero-blue: #0837ff;
	--nou-hero-blue-dark: #001fd2;
	--nou-hero-ink: #080d21;
	--nou-hero-muted: #52627c;
	--nou-hero-line: #dde6f7;
	--nou-hero-soft: #f5f8ff;
	background:
		radial-gradient(circle at 78% 22%, rgba(8, 55, 255, 0.12), transparent 32%),
		radial-gradient(circle at 52% 62%, rgba(8, 55, 255, 0.1), transparent 30%),
		linear-gradient(180deg, rgba(255, 255, 255, 0.72) 0%, rgba(247, 250, 255, 0.86) 100%);
	color: var(--nou-hero-ink);
	overflow: hidden;
	position: relative;
}

.nou-hero-banner::after {
	background-image: radial-gradient(rgba(8, 55, 255, 0.28) 1px, transparent 1px);
	background-size: 14px 14px;
	content: "";
	height: 150px;
	opacity: 0.55;
	pointer-events: none;
	position: absolute;
	right: 5vw;
	top: 34%;
	width: 180px;
}

.nou-hero-banner > * {
	position: relative;
	z-index: 1;
}

.nou-hero-banner .nou-hero-kicker {
	align-items: center;
	background: rgba(255, 255, 255, 0.78);
	border: 1px solid var(--nou-hero-line);
	border-radius: 999px;
	box-shadow: 0 18px 45px rgba(23, 43, 77, 0.08);
	color: var(--nou-hero-blue);
	display: inline-flex;
	font-size: 15px;
	font-weight: 600;
	gap: 10px;
	margin: 0;
	padding: 10px 18px;
}

.nou-hero-banner .nou-hero-kicker::before {
	background: var(--nou-hero-blue);
	border-radius: 999px;
	box-shadow: inset 0 0 0 4px rgba(255, 255, 255, 0.28);
	content: "";
	height: 18px;
	width: 18px;
}

.nou-hero-banner .nou-hero-title {
	max-width: 680px;
}

.nou-hero-banner .nou-hero-title strong {
	color: var(--nou-hero-blue);
	font-weight: inherit;
}

.nou-hero-banner .nou-hero-copy {
	color: var(--nou-hero-muted);
	max-width: 620px;
}

.nou-hero-banner .wp-block-button__link {
	box-shadow: 0 18px 34px rgba(8, 55, 255, 0.18);
}

.nou-hero-banner .is-style-outline .wp-block-button__link {
	background: rgba(255, 255, 255, 0.84);
	box-shadow: none;
}

.nou-hero-feature-row {
	display: flex;
	flex-wrap: nowrap;
	gap: 9px;
}

.nou-hero-feature {
	align-items: center;
	background: rgba(255, 255, 255, 0.72);
	border: 1px solid rgba(221, 230, 247, 0.72);
	border-radius: 999px;
	box-shadow: 0 14px 28px rgba(23, 43, 77, 0.06);
	color: #394762;
	display: inline-flex;
	font-size: 14px;
	gap: 8px;
	margin: 0;
	padding: 10px 13px;
	white-space: nowrap;
}

.nou-hero-feature::before {
	background: #edf3ff;
	border: 1px solid #d8e5ff;
	border-radius: 999px;
	color: var(--nou-hero-blue);
	content: "+";
	display: inline-grid;
	font-size: 12px;
	font-weight: 700;
	height: 20px;
	line-height: 1;
	place-items: center;
	width: 20px;
}

.nou-hero-visual {
	position: relative;
}

.nou-hero-visual-image {
	margin: 0;
}

.nou-hero-visual-image img {
	display: block;
	height: auto;
	margin-left: auto;
	max-width: min(100%, 860px);
	width: 100%;
}

.nou-hero-browser {
	background: #ffffff;
	border: 1px solid var(--nou-hero-line);
	border-radius: 14px;
	box-shadow: 0 30px 80px rgba(17, 32, 69, 0.13);
	overflow: hidden;
}

.nou-hero-browser-bar {
	align-items: center;
	border-bottom: 1px solid #edf1f9;
	display: flex;
	gap: 14px;
	justify-content: space-between;
	min-height: 56px;
	padding: 0 26px;
}

.nou-hero-store {
	align-items: center;
	display: flex;
	font-size: 12px;
	font-weight: 700;
	gap: 10px;
	margin: 0;
}

.nou-hero-store::before {
	color: var(--nou-hero-blue);
	content: "N";
	font-size: 18px;
	font-weight: 900;
}

.nou-hero-browser-nav {
	color: #606d82;
	display: flex;
	font-size: 11px;
	gap: 18px;
	margin: 0;
}

.nou-hero-browser-body {
	align-items: center;
	background:
		radial-gradient(circle at 82% 34%, rgba(31, 119, 255, 0.18), transparent 28%),
		linear-gradient(90deg, #ffffff 0%, #ffffff 49%, #eef6ff 50%, #e9f2ff 100%);
	display: grid;
	gap: 28px;
	grid-template-columns: 1fr 1fr;
	min-height: 304px;
	padding: 52px 54px;
}

.nou-hero-shop-copy {
	max-width: 270px;
}

.nou-hero-shop-copy h3,
.nou-hero-shop-copy p {
	margin: 0;
}

.nou-hero-shop-copy h3 {
	font-size: 28px;
	line-height: 1.08;
}

.nou-hero-shop-copy p {
	color: var(--nou-hero-muted);
	font-size: 13px;
	line-height: 1.5;
	margin-top: 14px;
}

.nou-hero-mini-button {
	background: var(--nou-hero-blue);
	border-radius: 8px;
	color: #ffffff;
	display: inline-flex;
	font-size: 12px;
	font-weight: 700;
	margin-top: 20px;
	padding: 11px 16px;
}

.nou-hero-product-scene {
	align-items: end;
	display: grid;
	grid-template-columns: 1fr 68px;
	justify-items: center;
	min-height: 230px;
}

.nou-hero-chair {
	background: linear-gradient(145deg, #2d6da6 0%, #133f77 100%);
	border-radius: 48px 48px 18px 18px;
	box-shadow: inset 18px 14px 26px rgba(255, 255, 255, 0.12), 0 28px 34px rgba(11, 42, 83, 0.18);
	height: 164px;
	position: relative;
	width: 190px;
}

.nou-hero-chair::before,
.nou-hero-chair::after {
	background: linear-gradient(145deg, #326fab, #123e77);
	border-radius: 44px 44px 18px 18px;
	content: "";
	position: absolute;
	top: 54px;
}

.nou-hero-chair::before {
	height: 116px;
	left: -38px;
	transform: rotate(-8deg);
	width: 78px;
}

.nou-hero-chair::after {
	height: 116px;
	right: -38px;
	transform: rotate(8deg);
	width: 78px;
}

.nou-hero-plant {
	background: #ffffff;
	border-radius: 999px 999px 12px 12px;
	box-shadow: 0 18px 26px rgba(20, 38, 74, 0.14);
	height: 58px;
	position: relative;
	width: 62px;
}

.nou-hero-plant::before {
	color: #63a351;
	content: "|||";
	font-size: 46px;
	font-weight: 900;
	left: 12px;
	position: absolute;
	top: -44px;
	transform: rotate(-18deg);
}

.nou-hero-panel,
.nou-hero-stats {
	background: rgba(255, 255, 255, 0.9);
	border: 1px solid var(--nou-hero-line);
	border-radius: 14px;
	box-shadow: 0 24px 60px rgba(17, 32, 69, 0.13);
	position: absolute;
}

.nou-hero-panel {
	left: -54px;
	padding: 18px;
	top: 122px;
	width: 158px;
}

.nou-hero-panel-title,
.nou-hero-stats-label {
	color: #59677d;
	font-size: 11px;
	font-weight: 700;
	margin: 0 0 12px;
}

.nou-hero-control {
	background: #f5f7fb;
	border-radius: 8px;
	height: 11px;
	margin-top: 11px;
	overflow: hidden;
}

.nou-hero-control span,
.nou-hero-control-fill {
	background: var(--nou-hero-blue);
	display: block;
	height: 100%;
	width: 64%;
}

.nou-hero-stats {
	padding: 20px;
	right: -38px;
	top: 210px;
	width: 176px;
}

.nou-hero-stats strong {
	display: block;
	font-size: 23px;
	line-height: 1;
	margin-bottom: 8px;
}

.nou-hero-stats em {
	color: #16a75c;
	font-size: 12px;
	font-style: normal;
	font-weight: 700;
}

.nou-hero-chart {
	align-items: end;
	display: flex;
	gap: 7px;
	height: 70px;
	margin-top: 20px;
}

.nou-hero-chart span,
.nou-hero-chart .nou-hero-chart-bar {
	background: linear-gradient(180deg, #7db2ff 0%, var(--nou-hero-blue) 100%);
	border-radius: 4px 4px 0 0;
	flex: 1;
}

.nou-hero-cards {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	margin-top: 30px;
}

.nou-hero-card {
	background: rgba(255, 255, 255, 0.84);
	border: 1px solid var(--nou-hero-line);
	border-radius: 12px;
	box-shadow: 0 18px 40px rgba(17, 32, 69, 0.08);
	padding: 22px;
}

.nou-hero-card p {
	color: var(--nou-hero-muted);
	font-size: 13px;
	line-height: 1.45;
	margin: 5px 0 0;
}

.nou-hero-card strong {
	display: block;
	font-size: 15px;
}

.nou-hero-card strong::before {
	border: 1px solid #cfe0ff;
	border-radius: 8px;
	color: var(--nou-hero-blue);
	content: "N";
	display: inline-grid;
	font-size: 13px;
	height: 26px;
	margin-right: 10px;
	place-items: center;
	width: 26px;
}

@media (max-width: 1100px) {
	.nou-hero-panel,
	.nou-hero-stats {
		position: static;
		width: auto;
	}

	.nou-hero-visual {
		display: grid;
		gap: 18px;
		min-height: auto;
	}

	.nou-hero-cards {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 781px) {
	.nou-hero-banner::after {
		display: none;
	}

	.nou-hero-browser-body {
		grid-template-columns: 1fr;
		padding: 34px 24px;
	}

	.nou-hero-browser-nav {
		display: none;
	}

	.nou-hero-cards {
		grid-template-columns: 1fr;
	}

	.nou-hero-feature-row {
		display: grid;
		gap: 10px;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		width: 100%;
	}

	.nou-hero-feature {
		font-size: 13px;
		justify-content: flex-start;
		line-height: 1.3;
		min-height: 46px;
		padding: 9px 11px;
		white-space: nowrap;
	}
}

@media (max-width: 420px) {
	.nou-hero-feature-row {
		grid-template-columns: 1fr;
	}
}
