.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	padding: 0.8rem 1.4rem;
	border-radius: var(--radius-pill);
	border: 1px solid transparent;
	font-weight: 600;
	letter-spacing: 0.01em;
	min-height: 44px;
}

.btn--primary {
	background: linear-gradient(135deg, #be9757 0%, #d9ba80 100%);
	color: #132643;
	box-shadow: 0 10px 24px rgba(195, 155, 91, 0.35);
}

.btn--primary:hover,
.btn--primary:focus-visible {
	transform: translateY(-2px);
	background: linear-gradient(135deg, #d1ab6d 0%, #e2c48c 100%);
	box-shadow: 0 14px 28px rgba(195, 155, 91, 0.38);
}

.btn--ghost {
	color: #f3f8ff;
	border-color: rgba(226, 236, 250, 0.42);
	backdrop-filter: blur(4px);
}

.btn--ghost:hover,
.btn--ghost:focus-visible {
	background: rgba(255, 255, 255, 0.12);
}

.btn--secondary {
	border-color: rgba(15, 35, 65, 0.22);
	color: var(--color-heading);
	background: var(--color-white);
}

.btn--secondary:hover,
.btn--secondary:focus-visible {
	border-color: rgba(15, 35, 65, 0.5);
	transform: translateY(-2px);
}

.badge-list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
}

.badge {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: 0.45rem 0.75rem;
	border-radius: var(--radius-pill);
	border: 1px solid rgba(195, 155, 91, 0.35);
	background: rgba(195, 155, 91, 0.12);
	font-size: 0.85rem;
	font-weight: 600;
	color: #f2f7ff;
}

.badge--light {
	color: #244268;
	background: rgba(21, 61, 111, 0.08);
	border-color: rgba(36, 66, 104, 0.24);
}

.hero-trust {
	margin-top: var(--space-6);
	display: grid;
	gap: var(--space-2);
}

.hero-trust li {
	position: relative;
	width: fit-content;
	padding-left: 1.2rem;
	color: rgba(238, 246, 255, 0.95);
	text-align: left;
}

.hero-trust li::before {
	content: "";
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--color-gold);
	position: absolute;
	left: 0;
	top: 0.55rem;
}

.card {
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-5);
	box-shadow: var(--shadow-soft);
}

.card h3 {
	margin-bottom: var(--space-2);
}

.card p {
	color: var(--color-text);
}

.card-list {
	display: grid;
	gap: var(--space-2);
	margin-top: var(--space-3);
}

.card-list li {
	position: relative;
	padding-left: 1rem;
	color: var(--color-muted);
	font-size: 0.95rem;
}

.card-list li::before {
	content: "";
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: rgba(15, 35, 65, 0.5);
	position: absolute;
	left: 0;
	top: 0.6rem;
}

.highlight-panel {
	border-radius: var(--radius-xl);
	background: var(--gradient-premium);
	color: #f4f8ff;
	padding: clamp(1.6rem, 4vw, 3rem);
	box-shadow: var(--shadow-premium);
}

.highlight-panel h2,
.highlight-panel h3,
.highlight-panel p {
	color: inherit;
}

.highlight-panel__values {
	margin-top: var(--space-5);
	display: grid;
	gap: var(--space-3);
}

.highlight-panel__value {
	border: 1px solid rgba(210, 222, 239, 0.24);
	border-radius: var(--radius-md);
	padding: var(--space-4);
	background: rgba(255, 255, 255, 0.06);
}

.highlight-panel__visual {
	margin-top: var(--space-5);
	width: min(100%, 320px);
	aspect-ratio: 4 / 3;
	object-fit: cover;
	object-position: center 18%;
	display: block;
	border-radius: var(--radius-md);
	border: 1px solid rgba(210, 222, 239, 0.2);
}

.metric {
	display: grid;
	gap: var(--space-1);
}

.metric strong {
	font-size: 1.5rem;
	color: var(--color-heading);
}

.segment-card {
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	background: var(--color-white);
	padding: var(--space-5);
	box-shadow: var(--shadow-soft);
}

.segment-card--dark {
	border-color: var(--color-border-dark);
	background: rgba(7, 23, 48, 0.55);
	color: #d9e8fb;
}

.segment-card--dark h3,
.segment-card--dark p {
	color: inherit;
}

.icon-chip {
	width: 2.2rem;
	aspect-ratio: 1;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: var(--space-3);
	border: 1px solid rgba(195, 155, 91, 0.34);
	background: rgba(195, 155, 91, 0.12);
}

.process {
	counter-reset: process;
	display: grid;
	gap: var(--space-4);
}

.process li {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-4);
	background: var(--color-white);
	box-shadow: var(--shadow-soft);
}

.process li::before {
	counter-increment: process;
	content: counter(process);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	border-radius: 50%;
	margin-bottom: var(--space-3);
	background: rgba(15, 35, 65, 0.08);
	color: var(--color-heading);
	font-weight: 700;
}

.faq {
	--faq-gap: clamp(0.65rem, 1.4vw, 0.85rem);
	--faq-radius: clamp(0.95rem, 1.8vw, 1.05rem);
	--faq-padding-x: clamp(1rem, 1.8vw, 1.25rem);
	--faq-padding-y: clamp(0.95rem, 1.5vw, 1.1rem);
	--faq-answer-size: clamp(0.92rem, 0.88rem + 0.18vw, 0.98rem);
	width: 100%;
	display: grid;
	gap: var(--faq-gap);
}

.faq-item {
	border: 1px solid rgba(15, 35, 65, 0.12);
	border-radius: var(--faq-radius);
	overflow: hidden;
	background: linear-gradient(180deg, #ffffff 0%, #f9fbfe 100%);
	box-shadow: 0 8px 18px rgba(10, 29, 55, 0.04);
	transition:
		border-color var(--transition-base),
		background-color var(--transition-base),
		box-shadow var(--transition-base),
		transform var(--transition-base);
}

.faq-trigger {
	width: 100%;
	min-height: clamp(3.3rem, 5vw, 3.8rem);
	padding: var(--faq-padding-y) var(--faq-padding-x);
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: var(--space-3);
	text-align: left;
	color: var(--color-heading);
	font-size: clamp(1rem, 0.96rem + 0.18vw, 1.06rem);
	font-weight: 600;
	line-height: 1.35;
	transition:
		padding var(--transition-base),
		color var(--transition-base);
}

.faq-label {
	flex: 1;
	min-width: 0;
}

.faq-icon {
	position: relative;
	flex: 0 0 auto;
	width: 1.75rem;
	height: 1.75rem;
	margin-top: 0.05rem;
	border: 1px solid rgba(15, 35, 65, 0.12);
	border-radius: 50%;
	background: rgba(15, 35, 65, 0.03);
	color: var(--color-gold);
	transition:
		transform var(--transition-base),
		border-color var(--transition-base),
		background-color var(--transition-base);
}

.faq-icon::before,
.faq-icon::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 0.72rem;
	height: 1.5px;
	border-radius: var(--radius-pill);
	background: currentColor;
	transform: translate(-50%, -50%);
	transition:
		transform var(--transition-base),
		opacity var(--transition-fast);
}

.faq-icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.faq-panel {
	display: grid;
	grid-template-rows: 0fr;
	opacity: 0;
	visibility: hidden;
	transition:
		grid-template-rows var(--transition-slow),
		opacity var(--transition-base),
		visibility 0s linear var(--transition-base);
}

.faq-panel-inner {
	min-height: 0;
	overflow: hidden;
	padding: 0 var(--faq-padding-x) var(--space-4);
	color: var(--color-muted);
	font-size: var(--faq-answer-size);
	line-height: 1.65;
	opacity: 0;
	transform: translateY(-0.35rem);
	transition:
		opacity var(--transition-base),
		transform var(--transition-base);
}

.faq-item.is-open {
	border-color: rgba(195, 155, 91, 0.34);
	background: var(--color-white);
	box-shadow: 0 12px 24px rgba(10, 29, 55, 0.05);
}

.faq-item.is-open .faq-trigger {
	padding-bottom: 0.6rem;
}

.faq-item.is-open .faq-icon {
	transform: rotate(180deg);
	border-color: rgba(195, 155, 91, 0.34);
	background: rgba(195, 155, 91, 0.1);
}

.faq-item.is-open .faq-icon::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(90deg) scaleX(0);
}

.faq-item.is-open .faq-panel {
	grid-template-rows: 1fr;
	opacity: 1;
	visibility: visible;
	transition-delay: 0s, 0s, 0s;
}

.faq-item.is-open .faq-panel-inner {
	opacity: 1;
	transform: translateY(0);
}

.faq-trigger:focus-visible {
	outline: none;
}

.faq-item:focus-within {
	border-color: rgba(195, 155, 91, 0.42);
	box-shadow:
		0 0 0 3px rgba(195, 155, 91, 0.14),
		0 12px 24px rgba(10, 29, 55, 0.05);
}

@media (hover: hover) {
	.faq-item:hover {
		border-color: rgba(15, 35, 65, 0.18);
		box-shadow: 0 12px 24px rgba(10, 29, 55, 0.05);
		transform: translateY(-1px);
	}

	.faq-item:hover .faq-icon {
		border-color: rgba(195, 155, 91, 0.28);
		background: rgba(195, 155, 91, 0.08);
	}
}

@media (max-width: 767px) {
	.faq {
		--faq-gap: 0.6rem;
		--faq-padding-x: 0.95rem;
		--faq-padding-y: 0.9rem;
		--faq-answer-size: 0.93rem;
	}

	.faq-trigger {
		font-size: 0.98rem;
		gap: 0.8rem;
	}

	.faq-item.is-open .faq-trigger {
		padding-bottom: 0.55rem;
	}

	.faq-icon {
		width: 1.65rem;
		height: 1.65rem;
	}

	.faq-panel-inner {
		line-height: 1.6;
	}
}

@media (prefers-reduced-motion: reduce) {
	.faq-item,
	.faq-trigger,
	.faq-icon,
	.faq-panel,
	.faq-panel-inner {
		transition-duration: 0.01ms;
		transition-delay: 0s;
	}

	.faq-panel-inner {
		transform: none;
	}
}

.cta-banner {
	border-radius: var(--radius-xl);
	padding: clamp(1.6rem, 4vw, 2.8rem);
	background: linear-gradient(135deg, #0a2243 0%, #0f3464 100%);
	color: #f4f8ff;
	box-shadow: var(--shadow-premium);
	display: grid;
	gap: var(--space-4);
}

.cta-banner h2,
.cta-banner p {
	color: inherit;
}

.contact-card {
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	background: var(--color-white);
	padding: var(--space-5);
	box-shadow: var(--shadow-soft);
	display: grid;
	gap: var(--space-3);
}

.contact-card__icon {
	width: 2.3rem;
	height: 2.3rem;
}

.products-layout {
	display: grid;
	gap: var(--space-5);
}

.product-nav {
	align-self: start;
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	background: var(--color-white);
	box-shadow: var(--shadow-soft);
	padding: var(--space-4);
}

.product-nav ul {
	display: grid;
	gap: var(--space-2);
}

.product-nav a {
	display: block;
	padding: 0.65rem 0.8rem;
	border-radius: var(--radius-sm);
	color: var(--color-heading);
	font-weight: 600;
	font-size: 0.92rem;
}

.product-nav a:hover,
.product-nav a:focus-visible,
.product-nav a.is-active {
	background: rgba(13, 42, 81, 0.08);
}

.product-nav a.is-active {
	color: var(--color-heading);
	box-shadow: inset 0 0 0 1px rgba(13, 42, 81, 0.14);
}

.product-section {
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	background: var(--color-white);
	box-shadow: var(--shadow-soft);
	padding: var(--space-5);
	scroll-margin-top: 100px;
}

.product-section + .product-section {
	margin-top: var(--space-4);
}

.product-items {
	display: grid;
	gap: var(--space-3);
	margin-top: var(--space-4);
}

.product-item {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-4);
	background: var(--color-surface);
}

.product-item h3 {
	font-size: 1.05rem;
}

.product-grid {
	display: grid;
	gap: var(--space-2);
	margin-top: var(--space-3);
}

.product-grid span {
	color: var(--color-muted);
	font-size: 0.93rem;
}

.product-grid strong {
	color: var(--color-heading);
	font-size: 0.9rem;
	margin-right: var(--space-2);
}

.product-section--status {
	display: grid;
	gap: var(--space-2);
	place-items: start;
}

.product-status {
	font-size: 0.97rem;
}

.product-status--muted {
	color: var(--color-muted);
}

.product-status--warning {
	color: #9a6700;
}

.product-status--error {
	color: #b42318;
}

.product-empty-state {
	margin-top: var(--space-4);
	padding: var(--space-4);
	border: 1px dashed var(--color-border);
	border-radius: var(--radius-md);
	background: var(--color-surface);
}

.product-meta-block {
	margin-top: var(--space-3);
}

.product-meta-block strong {
	display: inline-block;
	margin-bottom: var(--space-2);
	color: var(--color-heading);
}
