:root {
	--bg: #080b0d;
	--bg-soft: #0d1115;
	--panel: #171a1f;
	--panel-2: #1e2229;
	--line: rgba(255, 255, 255, 0.1);
	--text: #f6f7f4;
	--muted: #a4abb5;
	--dim: #707782;
	--orange: #ff8a1f;
	--orange-2: #ff6b00;
	--shadow: 0 24px 70px rgba(0, 0, 0, 0.42);
	--radius: 8px;
	--container: 1180px;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	background:
		radial-gradient(circle at 70% 6%, rgba(255, 138, 31, 0.16), transparent 26%),
		linear-gradient(180deg, #0c0f12 0%, var(--bg) 34%, #050708 100%);
	color: var(--text);
	font-family: Inter, Arial, sans-serif;
	font-size: 16px;
	line-height: 1.6;
	margin: 0;
}

body.menu-open {
	overflow: hidden;
}

a {
	color: inherit;
	text-decoration: none;
}

a:hover {
	color: var(--orange);
}

img {
	display: block;
	height: auto;
	max-width: 100%;
}

button,
input,
textarea,
select {
	font: inherit;
}

.container {
	margin-inline: auto;
	max-width: calc(var(--container) + 40px);
	padding-inline: 20px;
	width: 100%;
}

.screen-reader-text,
.skip-link {
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	overflow: hidden;
	position: absolute;
	white-space: nowrap;
	width: 1px;
}

.skip-link:focus {
	background: var(--orange);
	clip: auto;
	clip-path: none;
	color: #111;
	height: auto;
	left: 16px;
	padding: 10px 14px;
	top: 16px;
	width: auto;
	z-index: 10000;
}

.site-header {
	background: rgba(13, 15, 18, 0.84);
	border-bottom: 1px solid var(--line);
	left: 0;
	position: sticky;
	right: 0;
	top: 0;
	z-index: 100;
}

.site-header.is-scrolled {
	background: rgba(10, 12, 15, 0.96);
	box-shadow: 0 12px 38px rgba(0, 0, 0, 0.28);
}

.header-inner {
	align-items: center;
	display: grid;
	gap: 22px;
	grid-template-columns: auto 1fr auto;
	min-height: 78px;
}

.brand {
	align-items: center;
	display: inline-flex;
	gap: 10px;
}

.brand-mark {
	align-items: center;
	background: linear-gradient(135deg, var(--orange), #d13b00);
	border: 1px solid rgba(255, 255, 255, 0.35);
	border-radius: 8px;
	box-shadow: 0 10px 24px rgba(255, 107, 0, 0.22);
	color: #fff;
	display: inline-flex;
	font-weight: 900;
	height: 34px;
	justify-content: center;
	width: 34px;
}

.brand strong {
	display: block;
	font-size: 24px;
	font-weight: 900;
	letter-spacing: 0;
	line-height: 1;
}

.brand strong span {
	color: var(--orange);
}

.brand small {
	color: var(--muted);
	display: block;
	font-size: 10px;
	font-weight: 600;
	line-height: 1.2;
	margin-top: 2px;
}

.custom-logo-link img {
	max-height: 54px;
	width: auto;
}

.primary-navigation {
	justify-self: center;
}

.menu {
	align-items: center;
	display: flex;
	gap: 10px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.menu a {
	border-radius: 999px;
	color: rgba(246, 247, 244, 0.9);
	display: inline-flex;
	font-size: 14px;
	font-weight: 700;
	padding: 8px 12px;
}

.menu a:hover,
.current-menu-item > a {
	background: rgba(255, 138, 31, 0.12);
	color: var(--orange);
}

.header-actions {
	align-items: center;
	display: flex;
	gap: 12px;
	justify-self: end;
}

.header-phone {
	color: var(--text);
	display: grid;
	font-weight: 900;
	line-height: 1.1;
	text-align: right;
	white-space: nowrap;
}

.header-phone small {
	color: var(--muted);
	font-size: 10px;
	font-weight: 600;
	margin-top: 3px;
}

.icon-link {
	align-items: center;
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid var(--line);
	border-radius: 999px;
	color: var(--text);
	display: inline-flex;
	font-size: 15px;
	font-weight: 900;
	height: 38px;
	justify-content: center;
	min-width: 38px;
	position: relative;
}

.icon-link:hover {
	background: var(--orange);
	color: #111;
}

.cart-link span {
	background: var(--orange);
	border-radius: 999px;
	color: #111;
	font-size: 11px;
	min-width: 18px;
	padding: 2px 5px;
}

.menu-toggle {
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	display: none;
	height: 40px;
	padding: 0;
	width: 40px;
}

.menu-toggle span:not(.screen-reader-text) {
	background: var(--text);
	display: block;
	height: 2px;
	margin: 4px auto;
	width: 18px;
}

.site-main {
	min-height: 50vh;
	overflow: hidden;
}

.hero {
	min-height: 680px;
	padding: 86px 0 52px;
	position: relative;
}

.hero::before {
	background:
		linear-gradient(90deg, rgba(8, 11, 13, 0.96) 0%, rgba(8, 11, 13, 0.72) 44%, rgba(8, 11, 13, 0.34) 100%),
		radial-gradient(circle at 78% 20%, rgba(255, 138, 31, 0.28), transparent 24%),
		linear-gradient(180deg, transparent 0%, var(--bg) 100%);
	content: "";
	inset: 0;
	position: absolute;
}

.hero-grid {
	align-items: center;
	display: grid;
	gap: 40px;
	grid-template-columns: minmax(0, 0.88fr) minmax(420px, 1.12fr);
	position: relative;
	z-index: 1;
}

.eyebrow {
	color: var(--orange);
	font-size: 13px;
	font-weight: 900;
	letter-spacing: 0.08em;
	margin: 0 0 14px;
	text-transform: uppercase;
}

.hero h1 {
	font-size: clamp(46px, 5vw, 76px);
	letter-spacing: 0;
	line-height: 0.98;
	margin: 0;
	max-width: 720px;
}

.hero-copy > p:not(.eyebrow) {
	color: var(--muted);
	font-size: 18px;
	margin: 24px 0 0;
	max-width: 560px;
}

.hero-benefits {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(3, 1fr);
	margin-top: 28px;
	max-width: 620px;
}

.hero-benefits span {
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	color: var(--text);
	font-size: 12px;
	font-weight: 800;
	padding: 14px;
}

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

.button,
.wp-element-button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
	align-items: center;
	border: 0;
	border-radius: var(--radius);
	cursor: pointer;
	display: inline-flex;
	font-weight: 900;
	gap: 10px;
	justify-content: center;
	min-height: 50px;
	padding: 13px 20px;
	transition: transform 180ms ease, background 180ms ease, color 180ms ease, border-color 180ms ease;
}

.button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
	transform: translateY(-1px);
}

.button-primary,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
	background: linear-gradient(135deg, var(--orange), var(--orange-2));
	box-shadow: 0 18px 36px rgba(255, 107, 0, 0.22);
	color: #111;
}

.button-primary::after {
	content: "→";
}

.button-ghost {
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(255, 255, 255, 0.22);
	color: var(--text);
}

.button-ghost:hover {
	border-color: var(--orange);
	color: var(--orange);
}

.hero-media {
	min-height: 560px;
	position: relative;
}

.hero-media::before {
	background: radial-gradient(circle, rgba(255, 138, 31, 0.24), transparent 52%);
	content: "";
	filter: blur(12px);
	inset: 4% 8% 10% 6%;
	position: absolute;
}

.hero-media img {
	filter: drop-shadow(0 40px 70px rgba(0, 0, 0, 0.68));
	margin-left: auto;
	max-height: 560px;
	object-fit: contain;
	position: relative;
	width: min(100%, 720px);
	z-index: 1;
}

.rating-card {
	background: rgba(24, 27, 32, 0.92);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	bottom: 42px;
	box-shadow: var(--shadow);
	display: grid;
	gap: 2px;
	padding: 16px 20px;
	position: absolute;
	right: 12px;
	z-index: 2;
}

.rating-card strong {
	font-size: 18px;
}

.rating-card span {
	color: var(--orange);
	letter-spacing: 0.08em;
}

.rating-card small {
	color: var(--muted);
}

.trust-bar {
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	display: grid;
	gap: 1px;
	grid-template-columns: repeat(4, 1fr);
	margin-top: -28px;
	padding-block: 8px;
	position: relative;
	z-index: 4;
}

.trust-bar div {
	color: rgba(246, 247, 244, 0.84);
	font-size: 13px;
	font-weight: 800;
	padding: 18px;
}

.section {
	padding: 74px 0;
}

.section-heading {
	margin-bottom: 34px;
}

.section-heading.centered {
	text-align: center;
}

.section-heading h2,
.about-copy h2,
.faq-grid h2,
.page-header h1,
.content-card h1 {
	font-size: clamp(34px, 4vw, 54px);
	letter-spacing: 0;
	line-height: 1.05;
	margin: 0;
}

.section-heading h2 {
	margin-inline: auto;
	max-width: 820px;
}

.section-heading p:not(.eyebrow),
.about-copy p,
.content-card p {
	color: var(--muted);
}

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

.category-card,
.review-grid article,
.content-card,
.faq-grid,
.footer-top,
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	background: linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.035));
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
}

.category-card {
	overflow: hidden;
	padding: 18px;
	position: relative;
}

.category-card img {
	aspect-ratio: 1.12 / 1;
	background: radial-gradient(circle at 50% 40%, rgba(255, 138, 31, 0.14), transparent 42%), #20242b;
	border-radius: var(--radius);
	object-fit: cover;
	width: 100%;
}

.category-age {
	color: var(--orange);
	font-size: 13px;
	font-weight: 900;
	line-height: 1.35;
	margin: 18px 0 8px;
}

.category-card h3 {
	font-size: 17px;
	line-height: 1.25;
	margin: 0 0 14px;
}

.category-card span {
	color: var(--muted);
	display: block;
	font-size: 14px;
}

.category-card a {
	align-items: center;
	background: var(--text);
	border-radius: 999px;
	bottom: 18px;
	color: #111;
	display: inline-flex;
	font-weight: 900;
	height: 34px;
	justify-content: center;
	position: absolute;
	right: 18px;
	width: 34px;
}

.center-action {
	margin-top: 26px;
	text-align: center;
}

.about-section {
	padding-top: 44px;
}

.about-grid {
	align-items: center;
	display: grid;
	gap: 24px;
	grid-template-columns: 0.75fr 1.25fr 0.45fr;
}

.about-copy p {
	max-width: 430px;
}

.check-list {
	display: grid;
	gap: 14px;
	list-style: none;
	margin: 28px 0;
	padding: 0;
}

.check-list li {
	color: var(--text);
	font-weight: 800;
	padding-left: 34px;
	position: relative;
}

.check-list li::before {
	align-items: center;
	background: rgba(255, 138, 31, 0.12);
	border: 1px solid rgba(255, 138, 31, 0.35);
	border-radius: 999px;
	color: var(--orange);
	content: "✓";
	display: inline-flex;
	height: 24px;
	justify-content: center;
	left: 0;
	position: absolute;
	top: 1px;
	width: 24px;
}

.about-media {
	border-radius: var(--radius);
	overflow: hidden;
	position: relative;
}

.about-media::after {
	background: linear-gradient(90deg, var(--bg) 0%, transparent 32%, transparent 70%, var(--bg) 100%);
	content: "";
	inset: 0;
	position: absolute;
}

.about-media img {
	aspect-ratio: 1.55 / 1;
	object-fit: cover;
	width: 100%;
}

.stats {
	display: grid;
	gap: 16px;
}

.stats div {
	background: linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.035));
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: 24px;
}

.stats strong {
	color: var(--orange);
	display: block;
	font-size: 34px;
	font-weight: 900;
	line-height: 1;
}

.stats span {
	color: var(--muted);
	display: block;
	font-size: 13px;
	margin-top: 8px;
}

.review-grid {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.review-grid article {
	padding: 24px;
}

.review-grid strong {
	display: block;
}

.review-grid span {
	color: var(--orange);
	display: block;
	margin: 4px 0 12px;
}

.review-grid p {
	color: var(--muted);
	margin: 0;
}

.brand-strip {
	align-items: center;
	background: rgba(255, 255, 255, 0.055);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(6, 1fr);
	margin-bottom: 26px;
	padding-block: 24px;
	text-align: center;
}

.brand-strip span {
	color: rgba(246, 247, 244, 0.86);
	font-size: 24px;
	font-weight: 900;
}

.faq-grid {
	display: grid;
	gap: 36px;
	grid-template-columns: 0.45fr 1fr;
	padding: 32px;
}

.faq-list {
	display: grid;
	gap: 10px;
}

.faq-list button {
	align-items: center;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	color: var(--text);
	cursor: pointer;
	display: flex;
	font-weight: 800;
	justify-content: space-between;
	padding: 17px 18px;
	text-align: left;
}

.faq-list button:hover,
.faq-list button.is-open {
	border-color: rgba(255, 138, 31, 0.4);
	color: var(--orange);
}

.site-footer {
	padding: 0 0 28px;
}

.footer-top {
	display: grid;
	gap: 40px;
	grid-template-columns: 1.4fr 0.8fr 0.9fr;
	padding: 32px;
}

.newsletter h2 {
	font-size: 32px;
	line-height: 1.05;
	margin: 0 0 12px;
}

.newsletter p {
	color: var(--muted);
}

.newsletter-form {
	display: flex;
	gap: 10px;
	margin-top: 22px;
	max-width: 430px;
}

.newsletter-form input,
.search-field,
.woocommerce input.input-text,
.woocommerce textarea,
.woocommerce select {
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	color: var(--text);
	min-height: 48px;
	padding: 11px 13px;
	width: 100%;
}

.newsletter-form button,
.search-form button {
	background: linear-gradient(135deg, var(--orange), var(--orange-2));
	border: 0;
	border-radius: var(--radius);
	color: #111;
	cursor: pointer;
	font-weight: 900;
	padding-inline: 18px;
}

.footer-column {
	display: grid;
	gap: 8px;
	align-content: start;
}

.footer-column h3 {
	margin: 0 0 8px;
}

.footer-column a,
.footer-column span,
.site-footer .menu a,
.footer-bottom {
	color: var(--muted);
}

.site-footer .menu {
	align-items: flex-start;
	flex-direction: column;
	gap: 2px;
}

.site-footer .menu a {
	font-size: 14px;
	padding: 3px 0;
}

.footer-bottom {
	border-top: 1px solid var(--line);
	display: flex;
	justify-content: space-between;
	margin-top: 24px;
	padding-top: 22px;
}

.content-layout,
.woocommerce-container {
	padding-bottom: 70px;
	padding-top: 56px;
}

.content-card {
	padding: 28px;
}

.page-header {
	padding: 56px 20px 28px;
}

.page-content > .entry-content > *:not(.alignfull) {
	margin-inline: auto;
	max-width: var(--container);
	padding-inline: 20px;
}

.entry-content a {
	color: var(--orange);
	font-weight: 800;
}

.search-form {
	display: flex;
	gap: 10px;
	max-width: 620px;
}

.search-form label {
	flex: 1;
}

.woocommerce ul.products {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	margin: 0;
	padding: 0;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
	content: none;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	float: none;
	margin: 0;
	padding: 16px;
	width: auto;
}

.woocommerce ul.products li.product a img {
	aspect-ratio: 1 / 1;
	background: var(--panel-2);
	border-radius: var(--radius);
	object-fit: cover;
	width: 100%;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	color: var(--text);
	font-size: 18px;
	line-height: 1.25;
	padding: 14px 0 0;
}

.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--orange);
	font-weight: 900;
}

.woocommerce span.onsale {
	background: var(--orange);
	border-radius: 999px;
	color: #111;
	font-weight: 900;
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	background: var(--panel);
	border-top-color: var(--orange);
	border-radius: var(--radius);
	color: var(--text);
}

@media (max-width: 1100px) {
	.header-phone,
	.heart-link {
		display: none;
	}

	.hero-grid,
	.about-grid {
		grid-template-columns: 1fr;
	}

	.hero-media {
		min-height: 0;
	}

	.hero-media img {
		margin-inline: auto;
	}

	.stats {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 900px) {
	.menu-toggle {
		display: block;
		justify-self: end;
	}

	.header-inner {
		grid-template-columns: auto auto auto;
	}

	.primary-navigation {
		background: rgba(10, 12, 15, 0.98);
		border-top: 1px solid var(--line);
		display: none;
		left: 0;
		padding: 18px 20px;
		position: absolute;
		right: 0;
		top: 78px;
	}

	.primary-navigation.is-open {
		display: block;
	}

	.primary-navigation .menu {
		align-items: stretch;
		flex-direction: column;
	}

	.category-grid,
	.trust-bar,
	.woocommerce ul.products {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.review-grid,
	.footer-top,
	.faq-grid {
		grid-template-columns: 1fr;
	}

	.brand-strip {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 640px) {
	.container {
		padding-inline: 16px;
	}

	.header-inner {
		min-height: 68px;
	}

	.brand strong {
		font-size: 20px;
	}

	.brand small {
		display: none;
	}

	.primary-navigation {
		top: 68px;
	}

	.hero {
		min-height: 0;
		padding: 42px 0 34px;
	}

	.hero h1 {
		font-size: 40px;
	}

	.hero-copy > p:not(.eyebrow) {
		font-size: 16px;
	}

	.hero-benefits,
	.category-grid,
	.trust-bar,
	.review-grid,
	.stats,
	.brand-strip,
	.woocommerce ul.products {
		grid-template-columns: 1fr;
	}

	.hero-actions,
	.newsletter-form,
	.search-form {
		flex-direction: column;
	}

	.button,
	.newsletter-form button,
	.search-form button {
		width: 100%;
	}

	.hero-media img {
		max-height: 360px;
	}

	.rating-card {
		bottom: 12px;
		right: 6px;
	}

	.trust-bar {
		margin-top: 0;
	}

	.section {
		padding: 52px 0;
	}

	.footer-top,
	.faq-grid {
		padding: 22px;
	}

	.footer-bottom {
		flex-direction: column;
		gap: 8px;
	}
}

