.apy-site {
	--apy-primary: #071f3d;
	--apy-accent: #d49a3a;
	--apy-cream: #f7f1e8;
	--apy-ink: #10243d;
	--apy-muted: #5f6b7a;
	--apy-line: #e8edf3;
	background: #fff;
	color: var(--apy-ink);
	font-family: Inter, Arial, Helvetica, sans-serif;
	line-height: 1.55;
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	overflow-x: clip;
	position: relative;
	isolation: isolate;
}

.apy-site * {
	box-sizing: border-box;
	letter-spacing: 0;
}

.apy-site img {
	max-width: 100%;
}

.apy-shell-body {
	margin: 0;
	overflow-x: hidden;
}

.apy-shell-body .apy-site {
	margin-left: 0;
	margin-right: 0;
}

.apy-container {
	width: min(1440px, calc(100vw - 64px));
	margin: 0 auto;
}

.apy-header {
	position: sticky;
	top: 0;
	z-index: 90;
	background: rgba(255, 255, 255, 0.96);
	border-bottom: 1px solid rgba(7, 31, 61, 0.07);
	backdrop-filter: blur(10px);
}

.apy-header-inner {
	min-height: 86px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 28px;
}

.apy-logo {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	color: var(--apy-primary);
	text-decoration: none;
	min-width: 236px;
}

.apy-logo-mark {
	width: 48px;
	height: 52px;
	display: grid;
	place-items: center;
	color: var(--apy-accent);
	border: 2px solid var(--apy-accent);
	border-radius: 4px;
	font-size: 27px;
	line-height: 1;
}

.apy-logo strong {
	display: block;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 38px;
	line-height: 1;
	font-weight: 600;
}

.apy-logo em {
	display: block;
	color: var(--apy-accent);
	font-style: normal;
	font-weight: 700;
	font-size: 16px;
}

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

.apy-nav a {
	color: var(--apy-primary);
	font-size: 13px;
	font-weight: 800;
	text-decoration: none;
	white-space: nowrap;
}

.apy-call-top,
.apy-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	min-height: 48px;
	padding: 0 22px;
	border-radius: 8px;
	font-weight: 800;
	text-decoration: none;
	white-space: nowrap;
}

.apy-call-top {
	flex: 0 0 auto;
}

.apy-call-top,
.apy-btn-primary {
	background: var(--apy-primary);
	color: #fff;
	box-shadow: 0 12px 24px rgba(7, 31, 61, 0.13);
}

.apy-call-top span,
.apy-btn-primary span {
	color: var(--apy-accent);
}

.apy-btn-ghost {
	color: var(--apy-accent);
	background: #fff;
	border: 1px solid rgba(212, 154, 58, 0.68);
}

.apy-menu-toggle {
	display: none !important;
	width: 42px;
	height: 42px;
	border: 1px solid var(--apy-line);
	border-radius: 8px;
	background: #fff;
	color: var(--apy-primary);
	font-size: 22px;
}

.apy-hero {
	overflow: hidden;
	background: linear-gradient(90deg, #fff 0%, #fff 42%, rgba(247, 241, 232, 0.65) 100%);
	border-bottom: 1px solid rgba(7, 31, 61, 0.05);
}

.apy-hero-inner {
	min-height: 630px;
	display: grid;
	grid-template-columns: minmax(420px, 0.9fr) minmax(0, 1.35fr);
	align-items: stretch;
}

.apy-hero-copy {
	padding: 72px 24px 72px 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.apy-eyebrow,
.apy-section-title span {
	color: var(--apy-accent);
	font-size: 14px;
	font-weight: 900;
}

.apy-hero h1,
.apy-subhero h1 {
	margin: 12px 0 18px;
	color: var(--apy-primary);
	font-family: Georgia, "Times New Roman", serif;
	font-size: 68px;
	line-height: 1.04;
	font-weight: 600;
}

.apy-hero p,
.apy-subhero p {
	max-width: 520px;
	color: #223a57;
	font-size: 17px;
}

.apy-hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	margin-top: 28px;
}

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

.apy-hero-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center right;
	display: block;
}

.apy-badge {
	position: absolute;
	top: 50px;
	right: 34px;
	width: 188px;
	aspect-ratio: 1;
	display: grid;
	place-content: center;
	gap: 7px;
	text-align: center;
	border-radius: 50%;
	background: var(--apy-primary);
	color: var(--apy-accent);
	border: 3px solid var(--apy-accent);
	outline: 8px solid var(--apy-primary);
	font-weight: 900;
	font-size: 16px;
}

.apy-hero-slider {
	position: relative;
	min-height: 680px;
	background: var(--apy-primary);
}

.apy-hero-slides,
.apy-hero-slide,
.apy-hero-shade {
	position: absolute;
	inset: 0;
}

.apy-hero-slides {
	z-index: 0;
}

.apy-hero-slide {
	opacity: 0;
	transition: opacity 900ms ease;
}

.apy-hero-slide.is-active {
	opacity: 1;
}

.apy-hero-slide img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
	object-position: center;
}

.apy-hero-shade {
	z-index: 1;
	background:
		linear-gradient(90deg, rgba(255, 255, 255, 0.96) 0%, rgba(255, 255, 255, 0.9) 32%, rgba(255, 255, 255, 0.32) 58%, rgba(255, 255, 255, 0.06) 100%),
		linear-gradient(180deg, rgba(7, 31, 61, 0.06), rgba(7, 31, 61, 0.03));
}

.apy-hero-slider .apy-hero-inner {
	position: relative;
	z-index: 2;
	min-height: 680px;
	grid-template-columns: minmax(420px, 0.82fr) minmax(260px, 1fr);
}

.apy-hero-slider .apy-hero-copy {
	max-width: 620px;
	padding: 84px 30px 84px 0;
}

.apy-hero-side {
	position: relative;
	min-height: 100%;
}

.apy-hero-side .apy-badge {
	top: 72px;
	right: 36px;
}

.apy-hero-dots {
	position: absolute;
	right: 42px;
	bottom: 48px;
	display: flex;
	gap: 10px;
	z-index: 3;
}

.apy-hero-dots button {
	width: 12px;
	height: 12px;
	padding: 0;
	border: 1px solid #fff;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.72);
	cursor: pointer;
}

.apy-hero-dots button.is-active {
	width: 34px;
	border-radius: 999px;
	background: var(--apy-accent);
	border-color: var(--apy-accent);
}

.apy-trust {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 20px;
	padding: 24px 0 18px;
}

.apy-trust div {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	font-weight: 800;
}

.apy-trust span,
.apy-card-icon,
.apy-why-list span {
	color: var(--apy-accent);
}

.apy-section-title {
	text-align: center;
	max-width: 800px;
	margin: 0 auto 24px;
}

.apy-section-title h2 {
	margin: 5px 0 4px;
	color: var(--apy-primary);
	font-family: Georgia, "Times New Roman", serif;
	font-size: 33px;
	line-height: 1.18;
}

.apy-section-title p {
	margin: 0;
	color: #43546a;
}

.apy-services {
	padding: 18px 0 24px;
}

.apy-service-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 22px;
}

.apy-service-card {
	position: relative;
	min-height: 318px;
	overflow: hidden;
	border: 1px solid var(--apy-line);
	border-radius: 8px;
	background: #fff;
	color: var(--apy-primary);
	text-decoration: none;
	box-shadow: 0 12px 24px rgba(7, 31, 61, 0.06);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.apy-service-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 32px rgba(7, 31, 61, 0.12);
}

.apy-service-card img {
	width: 100%;
	height: 158px;
	object-fit: cover;
	display: block;
	background: var(--apy-cream);
}

.apy-service-card div {
	position: relative;
	min-height: 154px;
	margin-top: -10px;
	padding: 34px 18px 18px;
	text-align: center;
	background: #fff;
	border-radius: 8px 8px 0 0;
}

.apy-card-icon {
	position: absolute;
	left: 50%;
	top: 138px;
	transform: translateX(-50%);
	z-index: 2;
	width: 50px;
	height: 50px;
	display: grid;
	place-items: center;
	background: var(--apy-accent);
	color: #fff;
	border-radius: 50%;
	border: 4px solid #fff;
	font-size: 22px;
}

.apy-service-card h3 {
	margin: 0 0 9px;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 21px;
	line-height: 1.08;
}

.apy-service-card p {
	margin: 0;
	color: #263b56;
	font-size: 13px;
}

.apy-areas {
	padding: 4px 0 48px;
}

.apy-area-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 22px;
}

.apy-area-card {
	border-right: 1px solid var(--apy-line);
	padding-right: 18px;
}

.apy-area-card:last-child {
	border-right: 0;
}

.apy-area-card h3 {
	margin: 0 0 8px;
	display: flex;
	gap: 9px;
	font-size: 16px;
	line-height: 1.16;
}

.apy-area-card h3 span {
	color: var(--apy-accent);
}

.apy-area-card a {
	color: var(--apy-primary);
	text-decoration: none;
}

.apy-area-card ul {
	margin: 0;
	padding-left: 18px;
	color: var(--apy-accent);
}

.apy-area-card li {
	font-size: 13px;
	margin: 2px 0;
}

.apy-why {
	background: linear-gradient(90deg, #faf7f1, #fff 48%, #fafafa);
	padding: 52px 0;
}

.apy-why-inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 220px minmax(0, 1.1fr);
	gap: 46px;
	align-items: center;
}

.apy-why h2 {
	margin: 6px 0 12px;
	color: var(--apy-primary);
	font-family: Georgia, "Times New Roman", serif;
	font-size: 38px;
	line-height: 1.05;
}

.apy-why img {
	width: 220px;
	height: 190px;
	object-fit: contain;
}

.apy-why-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px 28px;
}

.apy-why-list article {
	display: grid;
	grid-template-columns: 54px 1fr;
	gap: 0 14px;
	align-items: center;
}

.apy-why-list span {
	grid-row: span 2;
	width: 54px;
	height: 54px;
	display: grid;
	place-items: center;
	border: 1px solid var(--apy-accent);
	border-radius: 50%;
	font-size: 23px;
}

.apy-why-list p {
	margin: 2px 0 0;
	color: #526172;
	font-size: 13px;
}

.apy-bottom-cta {
	background: var(--apy-primary);
	color: #fff;
}

.apy-bottom-cta .apy-container {
	min-height: 112px;
	display: grid;
	grid-template-columns: 1.2fr 1.2fr auto auto;
	gap: 28px;
	align-items: center;
}

.apy-bottom-cta div {
	min-width: 0;
}

.apy-bottom-cta span {
	color: var(--apy-accent);
	font-size: 24px;
}

.apy-bottom-cta strong,
.apy-bottom-cta small {
	display: block;
}

.apy-bottom-cta strong {
	font-size: 21px;
}

.apy-satisfaction {
	width: 108px;
	height: 108px;
	display: grid;
	place-content: center;
	text-align: center;
	border-radius: 50%;
	background: var(--apy-accent);
	color: var(--apy-primary);
	font-weight: 900;
}

.apy-cta-buttons {
	display: grid;
	gap: 10px;
}

.apy-cta-buttons a,
.apy-fixed-buttons a {
	min-width: 150px;
	min-height: 42px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	color: #fff;
	text-decoration: none;
	font-weight: 900;
}

.apy-cta-buttons a:first-child,
.apy-fixed-wa {
	background: #43c65e;
}

.apy-cta-buttons a:last-child,
.apy-fixed-call {
	background: var(--apy-accent);
}

.apy-footer {
	background: #061a33;
	color: rgba(255, 255, 255, 0.82);
	border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.apy-footer-main {
	display: grid;
	grid-template-columns: minmax(260px, 1.35fr) repeat(3, minmax(150px, 0.75fr)) minmax(230px, 0.95fr);
	gap: 34px;
	padding: 54px 0 42px;
	align-items: start;
}

.apy-footer .apy-logo {
	color: #fff;
	min-width: 0;
}

.apy-footer .apy-logo strong {
	color: #fff;
}

.apy-footer-brand p {
	max-width: 360px;
	margin: 20px 0;
	color: rgba(255, 255, 255, 0.72);
}

.apy-footer h3 {
	margin: 0 0 16px;
	color: #fff;
	font-size: 16px;
}

.apy-footer-col,
.apy-footer-contact {
	display: grid;
	gap: 9px;
}

.apy-footer a {
	color: rgba(255, 255, 255, 0.78);
	text-decoration: none;
}

.apy-footer a:hover {
	color: var(--apy-accent);
}

.apy-footer-social {
	display: flex;
	gap: 10px;
}

.apy-footer-social a {
	width: 34px;
	height: 34px;
	display: inline-grid;
	place-items: center;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 50%;
	color: #fff;
}

.apy-footer-contact {
	padding: 22px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.05);
}

.apy-footer-contact strong {
	color: #fff;
	font-size: 24px;
}

.apy-footer-contact .apy-btn {
	width: 100%;
	min-height: 42px;
	margin-top: 4px;
}

.apy-footer-bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	background: rgba(0, 0, 0, 0.16);
}

.apy-footer-bottom .apy-container {
	min-height: 58px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	font-size: 13px;
}

.apy-fixed-buttons {
	position: fixed;
	right: 24px;
	bottom: 24px;
	z-index: 99;
	display: grid;
	gap: 10px;
}

.apy-subhero {
	padding: 84px 0 72px;
	background: linear-gradient(90deg, rgba(247, 241, 232, 0.9), #fff);
}

.apy-subhero h1 {
	font-size: 48px;
}

.apy-detail {
	padding: 54px 0 72px;
}

.apy-breadcrumb {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 22px;
	color: #748092;
	font-size: 14px;
}

.apy-breadcrumb a {
	color: var(--apy-accent);
	text-decoration: none;
}

.apy-detail h1,
.apy-detail h2 {
	color: var(--apy-primary);
	font-family: Georgia, "Times New Roman", serif;
}

.apy-detail h1 {
	font-size: 42px;
	line-height: 1.1;
	margin-top: 0;
}

.apy-detail-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 410px;
	gap: 58px;
	align-items: start;
}

.apy-detail p {
	color: #344963;
	font-size: 16px;
	max-width: 900px;
}

.apy-detail > p,
.apy-detail > h1 {
	max-width: 980px;
}

.apy-detail .apy-services.apy-container {
	width: 100%;
	max-width: 100%;
	margin: 46px 0 0;
}

.apy-detail .apy-service-grid {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.apy-detail-aside img,
.apy-gallery img {
	width: 100%;
	aspect-ratio: 3 / 2;
	object-fit: cover;
	border-radius: 8px;
	border: 1px solid var(--apy-line);
}

.apy-aside-box,
.apy-contact-card {
	margin-top: 16px;
	padding: 22px;
	border-radius: 8px;
	background: var(--apy-primary);
	color: #fff;
}

.apy-aside-box p {
	color: rgba(255, 255, 255, 0.82);
}

.apy-advantages {
	margin-top: 36px;
}

.apy-advantages > div,
.apy-chip-list {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.apy-advantages article,
.apy-chip-list a {
	padding: 12px 16px;
	border: 1px solid var(--apy-line);
	border-radius: 8px;
	background: #fff;
	color: var(--apy-primary);
	text-decoration: none;
	font-weight: 800;
}

.apy-faq,
.apy-related,
.apy-chip-section {
	margin-top: 38px;
}

.apy-faq details {
	border: 1px solid var(--apy-line);
	border-radius: 8px;
	padding: 16px 18px;
	margin: 10px 0;
	background: #fff;
}

.apy-faq summary {
	cursor: pointer;
	color: var(--apy-primary);
	font-weight: 900;
}

.apy-gallery {
	padding: 42px 0 56px;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 22px;
}

.apy-contact {
	padding: 56px 0 72px;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 420px;
	gap: 54px;
	align-items: start;
}

.apy-contact-card {
	display: grid;
	gap: 10px;
	margin-top: 0;
}

@media (max-width: 1100px) {
	.apy-header-inner {
		display: grid;
		grid-template-columns: auto auto;
		justify-content: space-between;
	}

	.apy-menu-toggle {
		display: grid !important;
		place-items: center;
	}

	.apy-nav,
	.apy-call-top {
		display: none;
	}

	.apy-header.is-open .apy-nav {
		position: absolute;
		left: 16px;
		right: 16px;
		top: 84px;
		display: grid;
		gap: 0;
		padding: 10px;
		background: #fff;
		border: 1px solid var(--apy-line);
		border-radius: 8px;
		box-shadow: 0 16px 32px rgba(7, 31, 61, 0.12);
	}

	.apy-nav a {
		padding: 12px;
	}

	.apy-hero-inner {
		grid-template-columns: 1fr;
		min-height: 0;
	}

	.apy-hero-slider,
	.apy-hero-slider .apy-hero-inner {
		min-height: 620px;
	}

	.apy-hero-copy {
		padding: 42px 0 28px;
	}

	.apy-hero-slider .apy-hero-copy {
		padding: 64px 0 32px;
	}

	.apy-hero-side {
		min-height: 220px;
	}

	.apy-hero-media {
		min-height: 420px;
	}

	.apy-service-grid,
	.apy-area-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.apy-area-card {
		border-right: 0;
	}

	.apy-why-inner,
	.apy-bottom-cta .apy-container,
	.apy-detail-grid,
	.apy-contact {
		grid-template-columns: 1fr;
	}

	.apy-detail .apy-service-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.apy-bottom-cta .apy-container {
		padding: 22px 0;
	}

	.apy-footer-main {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 700px) {
	.apy-container {
		width: min(100vw - 22px, 1440px);
	}

	.apy-logo {
		min-width: 0;
	}

	.apy-logo strong {
		font-size: 30px;
	}

	.apy-logo-mark {
		width: 40px;
		height: 44px;
	}

	.apy-hero h1 {
		font-size: 42px;
	}

	.apy-subhero h1,
	.apy-detail h1 {
		font-size: 34px;
	}

	.apy-hero-actions,
	.apy-btn {
		width: 100%;
	}

	.apy-hero-media {
		min-height: 330px;
	}

	.apy-hero-slider,
	.apy-hero-slider .apy-hero-inner {
		min-height: 640px;
	}

	.apy-hero-shade {
		background: linear-gradient(90deg, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0.74));
	}

	.apy-badge {
		width: 142px;
		right: 18px;
		top: 22px;
		font-size: 12px;
		outline-width: 5px;
	}

	.apy-hero-side .apy-badge {
		top: 18px;
		right: 18px;
	}

	.apy-hero-dots {
		right: 22px;
		bottom: 22px;
	}

	.apy-trust,
	.apy-service-grid,
	.apy-area-grid,
	.apy-detail .apy-service-grid,
	.apy-why-list,
	.apy-gallery {
		grid-template-columns: 1fr;
	}

	.apy-service-card {
		min-height: 286px;
	}

	.apy-why img {
		display: none;
	}

	.apy-fixed-buttons {
		left: 12px;
		right: 12px;
		bottom: 12px;
		grid-template-columns: 1fr 1fr;
	}

	.apy-fixed-buttons a {
		min-width: 0;
		font-size: 14px;
	}

	.apy-footer .apy-container {
		display: grid;
		justify-content: stretch;
		text-align: center;
	}

	.apy-footer-main {
		grid-template-columns: 1fr;
		padding: 36px 0 28px;
		text-align: left;
	}

	.apy-footer-bottom .apy-container {
		padding: 14px 0 86px;
	}
}
