@font-face {
	font-family: "Kosmos";
	src: url("../fonts/Kosmos-Regular.woff") format("woff");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}

html,
body {
	overscroll-behavior: none;
}

body {
	margin: 0;
	min-height: 100vh;
	background:
		url("../images/bg-stars.webp") center top / cover no-repeat fixed,
		linear-gradient(180deg, #000000 0%, #001726 45%, #00497c 100%) fixed;
	color: var(--wp--preset--color--space-muted);
	overflow-x: hidden;
}

.grecaptcha-badge {
	display: none;
}

.wp-site-blocks {
	min-height: 100vh;
	position: relative;
	isolation: isolate;
}

.wp-site-blocks > .mgk-hero,
.wp-site-blocks > header.wp-block-template-part,
.wp-site-blocks > footer.wp-block-template-part {
	margin-block-start: 0;
	margin-block-end: 0;
}

.wp-site-blocks > .mgk-template-main--page,
.wp-site-blocks > .mgk-template-main--portfolio {
	margin-block-start: 0;
}

.wp-site-blocks::before {
	content: "";
	position: fixed;
	inset: 0;
	background:
		radial-gradient(circle at 50% 100%, rgba(0, 114, 188, 0.3), transparent 40%),
		radial-gradient(circle at 50% 0%, rgba(0, 0, 0, 0.25), transparent 45%);
	pointer-events: none;
	z-index: -1;
}

.wp-site-blocks::after {
	content: "";
	position: fixed;
	inset: 0;
	background:
		linear-gradient(0deg, rgba(0, 73, 124, 0.95) 0%, rgba(0, 73, 124, 0.58) 8%, rgba(0, 73, 124, 0) 16%);
	pointer-events: none;
	z-index: 40;
	opacity: 1;
	transition: opacity 0.28s ease;
}

body.mgk-at-page-bottom .wp-site-blocks::after {
	opacity: 0;
}

body .is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
	max-width: var(--wp--style--global--wide-size);
}

a {
	text-decoration: none;
}

a:hover {
	color: #ffffff;
}

h1,
h2,
.wp-block-post-title,
.wp-block-query-title,
.wp-block-site-title {
	font-family: "Kosmos", sans-serif;
	font-weight: 400;
	letter-spacing: 0.03em;
	color: #fff;
}

:where(h3, h4, h5, h6, .wp-block-heading):not(h1):not(h2) {
	font-family: "Michroma", sans-serif;
	font-weight: 400;
	letter-spacing: 0.03em;
	color: var(--wp--preset--color--space-text);
}

.mgk-site-chrome {
	position: fixed;
	z-index: 60;
	display: flex;
	align-items: center;
}

.mgk-scroll-overlay-top {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	height: 170px;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0.97) 0%, rgba(0, 0, 0, 0.76) 38%, rgba(0, 0, 0, 0) 100%);
	opacity: 0;
	pointer-events: none;
	z-index: 45;
	transition: opacity 0.25s ease;
}

.mgk-scroll-overlay-top.is-visible {
	opacity: 1;
}

.mgk-site-chrome img {
	display: block;
	width: 100%;
	height: auto;
}

.mgk-site-chrome--top-left {
	top: 24px;
	left: 24px;
	width: clamp(44px, 4vw, 62px);
}

.mgk-site-chrome--top-right {
	top: 26px;
	right: 24px;
	z-index: 130;
}

.mgk-site-chrome--top-right > p,
.mgk-site-chrome--top-right > .wp-block-shortcode {
	display: contents;
	margin: 0;
}

.mgk-site-chrome--bottom-left {
	left: 24px;
	bottom: 24px;
	width: clamp(22px, 2vw, 28px);
}

.mgk-site-chrome--bottom-right {
	right: 24px;
	bottom: 24px;
	flex-direction: column;
	gap: 15px;
	width: clamp(18px, 1.6vw, 22px);
	z-index: 45;
}

.mgk-site-chrome--bottom-right .wp-block-image {
	margin: 0 !important;
}

.mgk-footer-tooltip a {
	position: relative;
	display: block;
}

.mgk-footer-tooltip__label {
	position: absolute;
	top: 50%;
	right: calc(100% + 12px);
	transform: translateY(-50%) translateX(8px);
	padding: 8px 12px;
	border: 1px solid rgba(110, 189, 241, 0.45);
	border-radius: 999px;
	background: rgba(0, 18, 36, 0.92);
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25);
	color: #ffffff;
	font-size: 9px;
	line-height: 1.2;
	white-space: nowrap;
	opacity: 0;
	pointer-events: none;
	transition:
		opacity 0.2s ease,
		transform 0.2s ease;
}

.mgk-footer-tooltip a:hover .mgk-footer-tooltip__label,
.mgk-footer-tooltip a:focus-visible .mgk-footer-tooltip__label {
	opacity: 1;
	transform: translateY(-50%) translateX(0);
}

#back-to-top {
	position: fixed;
	bottom: 60px;
    right: 12px;
	width: 50px;
	height: 50px;
	color: #fff;
	border-radius: 50%;
	text-align: center;
	line-height: 50px;
	font-size: 17px;
	cursor: pointer;
	display: none;
	z-index: 1000;
	transition: background-color 0.3s ease;
}

#back-to-top img {
    display: block;
    width: 16px;
    height: auto;
    margin: 16px auto 0;
}

#back-to-top:hover {
	background-color: #58bdeb24;
	animation: pulsebtt 1.5s infinite;
}

@keyframes pulsebtt {
	0%,
	100% {
		transform: scale(1);
	}

	50% {
		transform: scale(1.1);
	}
}

.progress-circle {
	position: absolute;
	top: -4px;
	left: -4px;
	width: calc(100% + 8px);
	height: calc(100% + 8px);
	pointer-events: none;
}

.progress-circle svg {
	width: 100%;
	height: 100%;
	transform: rotate(0deg);
}

.progress-circle .circle-bg {
	fill: none;
	stroke: #00356a;
	stroke-width: 1px;
}

.progress-circle .circle-progress {
	fill: none;
	stroke: #60b0ff;
	box-shadow: 0 0 10px #3999da, 0 0 14px #3999da, 0 0 14px #3999da;
	stroke-width: 1px;
	stroke-dasharray: 100, 100;
	stroke-dashoffset: 100;
	transition: stroke-dashoffset 0.1s linear;
}

.mgk-menu-toggle {
	width: 38px;
	height: 24px;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 0;
	border: 0;
	border-radius: 0;
	background: transparent;
	backdrop-filter: none;
	box-shadow: none;
	cursor: pointer;
	margin-bottom: 0;
	position: relative;
	z-index: 140;
	appearance: none;
	-webkit-appearance: none;
}

.mgk-menu-toggle__bars {
	display: block;
	width: 100%;
	height: 100%;
	position: relative;
	overflow: visible;
}

.mgk-menu-toggle br,
.mgk-menu-toggle__bars br,
.mgk-site-chrome--top-right br {
	display: none !important;
}

.mgk-menu-toggle__bars span {
	display: block;
	width: 100%;
	height: 4px;
	background: #ffffff;
	border-radius: 3px;
	position: absolute;
	left: 0;
	transition:
		width 0.3s ease,
		transform 0.3s ease,
		opacity 0.3s ease,
		background 0.3s ease,
		box-shadow 0.3s ease;
	transform-origin: center;
}

.mgk-menu-toggle__bars > span:nth-of-type(1) {
	top: 0;
}

.mgk-menu-toggle__bars > span:nth-of-type(2) {
	top: 50%;
	margin-top: -2px;
	width: 75%;
}

.mgk-menu-toggle__bars > span:nth-of-type(3) {
	bottom: 0;
	width: 50%;
}

.mgk-menu-toggle:hover .mgk-menu-toggle__bars span {
	width: 100%;
	background: #a6d7fa;
	box-shadow: 0 0 7px #516878, 0 0 10px #516878, 0 0 10px #516878;
}

.mgk-menu-toggle.active .mgk-menu-toggle__bars > span:nth-of-type(2) {
	opacity: 0;
	transform: scaleX(0);
}

.mgk-menu-toggle.active .mgk-menu-toggle__bars > span:nth-of-type(1) {
	top: 50%;
	bottom: auto;
	margin-top: -2px;
	width: 100%;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.mgk-menu-toggle.active .mgk-menu-toggle__bars > span:nth-of-type(3) {
	top: auto;
	bottom: 50%;
	margin-bottom: -2px;
	width: 100%;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

.mgk-overlay-nav {
	position: fixed;
	inset: 0;
	z-index: 100;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
	background-color: rgba(0, 0, 0, 0.38);
}

.wp-site-blocks > .wp-block-shortcode {
	display: contents;
}

.mgk-overlay-nav.visible {
	opacity: 1;
	visibility: visible;
}

.mgk-overlay-nav__inner {
	width: 100%;
	height: 100%;
	padding: 0;
	box-sizing: border-box;
	display: flex;
	align-items: stretch;
	justify-content: flex-end;
}

.mgk-overlay-nav__panel {
	width: clamp(360px, 34vw, 560px);
	height: 100%;
	padding: clamp(110px, 13vh, 150px) clamp(34px, 3vw, 48px) clamp(60px, 8vh, 90px);
	box-sizing: border-box;
	background:
		linear-gradient(180deg, rgba(0, 0, 0, 0.96) 0%, rgba(2, 14, 25, 0.98) 50%, rgba(0, 31, 54, 0.98) 100%);
	border-left: 1px solid rgba(76, 166, 255, 0.18);
	box-shadow: -24px 0 60px rgba(0, 0, 0, 0.28);
	transform: translateX(100%);
	transition: transform 0.35s ease;
	overflow-y: auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	gap: clamp(28px, 4vh, 42px);
}

.mgk-overlay-nav.visible .mgk-overlay-nav__panel {
	transform: translateX(0);
}

.mgk-overlay-nav__navigation.wp-block-navigation {
	width: 100%;
	max-width: none;
}

.mgk-overlay-nav__meta {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 40px;
	width: 100%;
	max-width: 240px;
	margin: 0 auto;
}

.mgk-overlay-nav__meta br,
.mgk-overlay-nav__meta p {
	display: none !important;
}

.mgk-overlay-nav__helmet {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 88px;
	height: 88px;
	border: 0;
	border-radius: 0;
	background: transparent;
	box-shadow: none;
	transition: filter 0.25s ease, transform 0.25s ease;
	animation: mgk-helmet-float 3.2s ease-in-out infinite;
	will-change: transform;
}

.mgk-overlay-nav__helmet:hover,
.mgk-overlay-nav__helmet:focus-visible {
	animation-play-state: paused;
	filter: drop-shadow(0 0 12px rgba(88, 188, 235, 0.58)) drop-shadow(0 0 22px rgba(88, 188, 235, 0.28));
	transform: translateY(-10px) rotate(-3deg) scale(1.06);
}

.mgk-overlay-nav__helmet img {
	display: block;
	width: 85px;
	height: auto;
}

@keyframes mgk-helmet-float {
	0%,
	100% {
		transform: translateY(0) rotate(-1deg);
		filter: drop-shadow(0 0 4px rgba(88, 188, 235, 0.12));
	}

	50% {
		transform: translateY(-8px) rotate(2deg);
		filter: drop-shadow(0 0 10px rgba(88, 188, 235, 0.32));
	}
}

.mgk-overlay-nav__languages {
	display: inline-flex;
	align-items: center;
	padding: 3px;
	border: 1px solid rgba(76, 166, 255, 0.18);
	border-radius: 999px;
	background: rgba(3, 20, 33, 0.78);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
	margin: 0;
}

.mgk-overlay-nav__language {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	min-width: 0;
	padding: 7px 10px;
	border-radius: 999px;
	color: #7ebcf6;
	font-size: 9px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	transition: color 0.25s ease, background 0.25s ease, box-shadow 0.25s ease;
}

.mgk-overlay-nav__language-flag {
	display: inline-block;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	overflow: hidden;
	flex: 0 0 14px;
}

.mgk-overlay-nav__language-flag img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.mgk-overlay-nav__language-code {
	display: inline-block;
	line-height: 1;
}

.mgk-overlay-nav__language:hover,
.mgk-overlay-nav__language:focus-visible {
	color: #ffffff;
}

.mgk-overlay-nav__language.is-active {
	background: linear-gradient(180deg, rgba(96, 176, 255, 0.24) 0%, rgba(54, 122, 186, 0.34) 100%);
	color: #ffffff;
	box-shadow: 0 0 14px rgba(88, 188, 235, 0.16);
}

.mgk-overlay-nav__navigation .wp-block-navigation__responsive-container,
.mgk-overlay-nav__navigation .wp-block-navigation__responsive-container-content {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}

.mgk-overlay-nav__navigation .wp-block-navigation__responsive-container-open,
.mgk-overlay-nav__navigation .wp-block-navigation__responsive-container-close {
	display: none !important;
}

.mgk-overlay-nav__navigation .wp-block-navigation__container {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	margin: 0 auto;
	padding: 0;
	list-style: none;
	width: min(100%, 240px);
	row-gap: 0;
}

.mgk-overlay-nav .wp-block-navigation-item {
	list-style: none;
	text-align: left;
	font-size: clamp(1.6rem, 2vw, 2rem);
	width: 100%;
	margin: 0 0 32px;
	position: relative;
}

.mgk-overlay-nav .wp-block-navigation-item:last-child {
	margin-bottom: 0;
}

.mgk-overlay-nav .wp-block-navigation-item__content {
	color: #fff;
	text-decoration: none;
	transition: color 0.6s ease, text-shadow 0.6s ease;
	position: relative;
	display: inline-flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 8px;
}

.mgk-overlay-nav .wp-block-navigation-item__label {
	display: block;
}

.mgk-overlay-nav .wp-block-navigation-item__description {
	display: block;
	width: min(260px, 100%);
	font-size: 13px;
	line-height: 1.5;
	opacity: 0.8;
	color: #60b0ff;
	text-shadow: none;
}

.mgk-overlay-nav .wp-block-navigation-item__content:hover,
.mgk-overlay-nav .wp-block-navigation-item__content:focus-visible {
	text-shadow: 0 0 10px #256692, 0 0 14px #256692, 0 0 14px #256692;
}

.mgk-overlay-nav .wp-block-navigation-item__content:hover .wp-block-navigation-item__description,
.mgk-overlay-nav .wp-block-navigation-item__content:focus-visible .wp-block-navigation-item__description {
	color: #8ec7ff;
}

.mgk-overlay-nav .wp-block-navigation-item__content::before {
	content: "";
	position: absolute;
	left: -30px;
	top: 50%;
	transform: translateY(-50%);
	width: 10px;
	height: 10px;
	background-color: #ff0000;
	border-radius: 2px;
	opacity: 0;
	transition: opacity 0.6s ease;
}

.mgk-overlay-nav .wp-block-navigation-item__content:hover::before,
.mgk-overlay-nav .wp-block-navigation-item__content:focus-visible::before {
	opacity: 1;
	animation: mgk-menu-pulse 1s infinite ease-out;
}

.mgk-overlay-nav .wp-block-navigation__submenu-icon {
	color: currentColor;
	position: absolute;
	right: 0;
	top: 0.2em;
}

.mgk-overlay-nav .wp-block-navigation-submenu__toggle {
	padding-right: 28px;
}

.mgk-overlay-nav .wp-block-navigation__submenu-container {
	background: transparent !important;
	border: 0 !important;
	padding: 14px 0 0 18px !important;
	position: static !important;
	width: 100% !important;
	min-width: 0 !important;
	margin: 0 !important;
	box-shadow: none !important;
	opacity: 1 !important;
	visibility: visible !important;
}

.mgk-overlay-nav .wp-block-navigation__submenu-container .wp-block-navigation-item {
	font-size: clamp(1.15rem, 1.4vw, 1.4rem);
	margin-bottom: 18px;
}

body.mgk-menu-open {
	overflow: hidden;
}

@keyframes mgk-menu-pulse {
	0% {
		box-shadow: 0 0 0 0 rgba(255, 0, 0, 0.5);
		opacity: 1;
	}

	50% {
		box-shadow: 0 0 0 10px rgba(255, 0, 0, 0);
		opacity: 0.6;
	}

	100% {
		box-shadow: 0 0 0 0 rgba(255, 0, 0, 0);
		opacity: 0;
	}
}

.mgk-hero {
	height: 100vh;
	min-height: 100vh;
	padding: 96px clamp(24px, 4vw, 48px) 96px;
	display: flex;
	align-items: center;
	overflow: hidden;
	box-sizing: border-box;
}

.mgk-hero__grid {
	width: 100%;
	max-width: 1310px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	align-items: center;
	gap: clamp(24px, 3vw, 48px);
	height: 100%;
}

.mgk-hero__copy {
	max-width: 520px;
	width: 100%;
	justify-self: center;
}

.mgk-hero__copy .wp-block-heading {
	margin-bottom: 1.5rem;
}

.mgk-hero__copy .mgk-hero__typewriter-title.has-large-font-size {
	font-size: clamp(2.52rem, 3.6vw, 4.14rem) !important;
}

.mgk-hero__typewriter-title {
	min-height: 1.1em;
	white-space: nowrap;
}

.mgk-typewriter-title {
	display: inline;
}

.mgk-typewriter-cursor {
	display: inline-block;
	width: 0.09em;
	height: 0.9em;
	margin-left: 0.12em;
	background: #58bceb;
	box-shadow: 0 0 9px rgba(88, 188, 235, 0.85), 0 0 18px rgba(88, 188, 235, 0.45);
	transform: translateY(0.08em);
	animation: mgk-typewriter-cursor 0.76s steps(2, start) infinite;
}

.mgk-typewriter-cursor--description {
	width: 0.14em;
	height: 0.95em;
	margin-left: 0.08em;
	background: #fff;
	box-shadow: 0 0 9px rgba(255, 255, 255, 0.9), 0 0 18px rgba(88, 188, 235, 0.45);
	transform: translateY(0.14em);
}

.mgk-hero__copy p {
	font-size: clamp(1rem, 1.35vw, 1.2rem);
}

.mgk-hero__typewriter-description {
	min-height: 5.4em;
}

.mgk-hero__buttons {
	margin-top: 2.2rem;
}

.mgk-hero__buttons .wp-block-button__link {
	border: 1px solid #58bceb;
	padding: 0.75rem 2.2rem;
	transition: color 0.6s ease, background-color 0.6s ease, border-color 0.6s ease, box-shadow 0.6s ease;
}

.mgk-hero__buttons .wp-block-button__link:hover,
.mgk-hero__buttons .wp-block-button__link:focus {
	color: white;
	background-color: #359dff75;
	border: 1px solid #60b0ff;
	box-shadow: 0 0 5px #256692, 0 0 7px #256692, 0 0 7px #256692;
}

.mgk-hero__art {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	min-height: 0;
	width: 100%;
}

.mgk-hero__art.is-layout-flow > * {
	margin-block-start: 0 !important;
	margin-block-end: 0 !important;
}

.mgk-hero__art .wp-block-image {
	margin: 0 !important;
}

.mgk-hero__ring {
	position: absolute;
	top: 50%;
	left: 50%;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	transform: translate(-50%, -50%);
	z-index: 1;
	pointer-events: none;
	will-change: transform, opacity;
	backface-visibility: hidden;
}

.mgk-hero__ring--small {
	width: min(32.2vw, 414px);
	height: min(32.2vw, 414px);
	background-image: url("../images/rings1.svg");
	animation: mgk-ring-spin 22s linear infinite, mgk-ring-flicker 3s ease-in-out infinite;
}

.mgk-hero__ring--large {
	width: min(50.6vw, 644px);
	height: min(50.6vw, 644px);
	background-image: url("../images/rings2.svg");
	animation: mgk-ring-spin-reverse 46s linear infinite, mgk-ring-flicker 1.4s ease-in-out infinite;
}

.mgk-hero__orbit-icons {
	position: absolute;
	top: 50%;
	left: 50%;
	width: min(60vw, 760px);
	height: min(60vw, 760px);
	transform: translate(-50%, -50%);
	z-index: 2;
	pointer-events: none;
	animation: mgk-orbit-spin 40s linear infinite;
	will-change: transform;
	backface-visibility: hidden;
}

.mgk-hero__orbit-item {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 34px;
	height: 34px;
	transform:
		translate(-50%, -50%)
		rotate(var(--angle))
		translateY(calc(-1 * min(20vw, 245px)))
		rotate(calc(-1 * var(--angle)));
	transform-origin: center;
}

.mgk-hero__orbit-item img {
	display: block;
	width: 100%;
	height: auto;
	animation: mgk-orbit-counter-spin 40s linear infinite;
	filter: drop-shadow(0 0 10px rgba(88, 188, 235, 0.15));
	will-change: transform;
	backface-visibility: hidden;
}

.mgk-hero__astronaut {
	position: relative;
	z-index: 3;
	max-width: min(100%, 483px);
}

@keyframes mgk-ring-spin {
	from {
		transform: translate(-50%, -50%) rotate(0deg);
	}

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

@keyframes mgk-ring-spin-reverse {
	from {
		transform: translate(-50%, -50%) rotate(0deg);
	}

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

@keyframes mgk-ring-flicker {
	0% {
		opacity: 1;
	}

	10% {
		opacity: 0.72;
	}

	20% {
		opacity: 0.5;
	}

	30% {
		opacity: 0.82;
	}

	40% {
		opacity: 0.62;
	}

	50% {
		opacity: 0.9;
	}

	60% {
		opacity: 0.44;
	}

	70% {
		opacity: 0.78;
	}

	80% {
		opacity: 0.56;
	}

	90% {
		opacity: 0.86;
	}

	100% {
		opacity: 1;
	}
}

@keyframes mgk-orbit-spin {
	from {
		transform: translate(-50%, -50%) rotate(0deg);
	}

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

@keyframes mgk-orbit-counter-spin {
	from {
		transform: rotate(0deg);
	}

	to {
		transform: rotate(-360deg);
	}
}

@keyframes mgk-typewriter-cursor {
	0%,
	45% {
		opacity: 1;
	}

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

@keyframes mgk-astronaut-float {
	0% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(-14px);
	}

	100% {
		transform: translateY(0);
	}
}

.mgk-template-main {
	padding:
		clamp(84px, 9vh, 112px)
		clamp(24px, 4vw, 48px)
		clamp(100px, 10vh, 130px);
}

body.error404 {
	height: 100vh;
	overflow: hidden;
}

body.error404 .wp-site-blocks {
	height: 100vh;
	min-height: 100vh;
	overflow: hidden;
}

.mgk-template-main--404 {
	height: 100vh;
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	box-sizing: border-box;
	padding:
		clamp(120px, 15vh, 150px)
		clamp(24px, 4vw, 48px)
		clamp(80px, 10vh, 110px);
}

.mgk-404 {
	width: min(100%, 540px);
	margin: 0 auto;
	text-align: center;
}

.mgk-404__helmet {
	margin: 0 auto clamp(34px, 5vh, 44px);
	width: clamp(120px, 12vw, 156px);
	animation: mgk-space-drift 7.2s ease-in-out infinite;
	transform-origin: center;
}

.mgk-404__helmet img {
	display: block;
	width: 100%;
	height: auto;
}

.mgk-404__title {
	margin: 0;
	position: relative;
	display: inline-block;
	font-family: "Michroma", sans-serif;
	font-weight: 400;
	font-size: clamp(4.25rem, 7.65vw, 6.3rem);
	line-height: 0.94;
	letter-spacing: 0.02em;
	animation: mgk-404-glitch 1s linear infinite;
}

.mgk-404__title::before,
.mgk-404__title::after {
	content: attr(title);
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	color: inherit;
	pointer-events: none;
}

.mgk-404__title::before {
	animation: mgk-404-glitch-top 1s linear infinite;
	clip-path: polygon(0 0, 100% 0, 100% 33%, 0 33%);
	text-shadow: 2px 0 #58bceb;
}

.mgk-404__title::after {
	animation: mgk-404-glitch-bottom 1.5s linear infinite;
	clip-path: polygon(0 67%, 100% 67%, 100% 100%, 0 100%);
	text-shadow: -2px 0 #ff0000;
}

.mgk-404__lead {
	margin: 0.85rem 0 0;
	color: #58bceb;
	font-size: clamp(1rem, 1.6vw, 1.35rem);
	letter-spacing: 0.12em;
}

.mgk-404__description {
	margin: 0.5rem 0 0;
	color: rgba(88, 188, 235, 0.8);
	font-size: clamp(0.92rem, 1.15vw, 1.02rem);
	letter-spacing: 0.07em;
}

.mgk-404__buttons {
	justify-content: center;
	margin-top: clamp(30px, 5vh, 42px);
}

@keyframes mgk-404-glitch {
	2%,
	64% {
		transform: translate(2px, 0) skew(0deg);
	}

	4%,
	60% {
		transform: translate(-2px, 0) skew(0deg);
	}

	62% {
		transform: translate(0, 0) skew(5deg);
	}
}

@keyframes mgk-404-glitch-top {
	2%,
	64% {
		transform: translate(2px, -2px);
	}

	4%,
	60% {
		transform: translate(-2px, 2px);
	}

	62% {
		transform: translate(13px, -1px) skew(-13deg);
	}
}

@keyframes mgk-404-glitch-bottom {
	2%,
	64% {
		transform: translate(-2px, 0);
	}

	4%,
	60% {
		transform: translate(-2px, 0);
	}

	62% {
		transform: translate(-22px, 5px) skew(21deg);
	}
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}

	.mgk-hero__ring,
	.mgk-hero__orbit-icons,
	.mgk-hero__orbit-item img,
	.mgk-overlay-nav__helmet,
	.astro3,
	.wpcf7 form .tab-button.active,
	.mgk-contact-switcher__button.is-active,
	.mgk-typewriter-cursor,
	.mgk-404__title,
	.mgk-404__title::before,
	.mgk-404__title::after {
		animation: none !important;
	}
}

/* --------------------- Listy tresci --------------------- */

body :where(ul, ol):not(:where(.wp-block-navigation, .wp-block-navigation *, .mgk-overlay-nav, .mgk-overlay-nav *, .mgk-contact-links, .mgk-contact-links *)) {
	list-style: none;
	color: var(--wp--preset--color--space-muted);
	margin: 0 0 1.2rem 0 !important;
	padding-left: clamp(12px, 1.05vw, 18px) !important;
}

body :where(ol):not(:where(.wp-block-navigation, .wp-block-navigation *, .mgk-overlay-nav, .mgk-overlay-nav *)) {
	counter-reset: mgk-list-counter;
}

body p:not(:where(.wp-block-navigation, .wp-block-navigation *, .mgk-overlay-nav, .mgk-overlay-nav *)),
body li:not(:where(.wp-block-navigation-item, .wp-block-navigation-item *, .mgk-overlay-nav *)) {
	font-size: 0.86rem;
	letter-spacing: 0.03em;
}

:where(h2, .wp-block-heading):is(h2) {
	font-size: clamp(1.32rem, 1.83vw, 1.74rem);
	line-height: 1.16;
}

:where(h3, .wp-block-heading):is(h3) {
	font-size: clamp(0.89rem, 1.19vw, 1.08rem);
	line-height: 1.2;
}

body :where(ul, ol):not(:where(.wp-block-navigation, .wp-block-navigation *, .mgk-overlay-nav, .mgk-overlay-nav *, .mgk-contact-links, .mgk-contact-links *)) :where(ul, ol) {
	margin-top: 0.6rem !important;
}

body :where(ul, ol):not(:where(.wp-block-navigation, .wp-block-navigation *, .mgk-overlay-nav, .mgk-overlay-nav *, .mgk-contact-links, .mgk-contact-links *)) > li:not(:where(.wp-block-navigation-item, .wp-block-navigation-item *)) {
	position: relative;
	color: inherit;
	line-height: 1.7;
	margin: 10px 0 !important;
	padding-left: 26px !important;
	text-shadow: none;
}

body :where(ol):not(:where(.wp-block-navigation, .wp-block-navigation *, .mgk-overlay-nav, .mgk-overlay-nav *, .mgk-contact-links, .mgk-contact-links *)) > li:not(:where(.wp-block-navigation-item, .wp-block-navigation-item *)) {
	counter-increment: mgk-list-counter;
}

body :where(ul, ol):not(:where(.wp-block-navigation, .wp-block-navigation *, .mgk-overlay-nav, .mgk-overlay-nav *, .mgk-contact-links, .mgk-contact-links *)) > li:not(:where(.wp-block-navigation-item, .wp-block-navigation-item *)) > * {
	color: inherit;
	text-shadow: none;
}

body :where(ul):not(:where(.wp-block-navigation, .wp-block-navigation *, .mgk-overlay-nav, .mgk-overlay-nav *, .mgk-contact-links, .mgk-contact-links *)) > li:not(:where(.wp-block-navigation-item, .wp-block-navigation-item *))::before {
	content: "";
	position: absolute;
	top: 0.86em;
	left: 0;
	transform: translateY(-50%);
	width: 7px;
	height: 7px;
	background-color: red;
	border-radius: 2px;
	box-shadow: 0 0 8px #ff0000, 0 0 11px #ff0000, 0 0 11px #ff0000;
}

body :where(ol):not(:where(.wp-block-navigation, .wp-block-navigation *, .mgk-overlay-nav, .mgk-overlay-nav *, .mgk-contact-links, .mgk-contact-links *)) > li:not(:where(.wp-block-navigation-item, .wp-block-navigation-item *))::before {
	content: counter(mgk-list-counter) ".";
	position: absolute;
	top: 0;
	left: 0;
	color: red;
	font-size: 0.92em;
	line-height: inherit;
	text-shadow: 0 0 8px #ff0000, 0 0 11px #ff0000, 0 0 11px #ff0000;
}

/* --------------------- Drobne elementy tresci --------------------- */

.wciecie {
	margin-left: 40px !important;
}

@keyframes mgk-space-drift {
	0%,
	100% {
		transform: translateY(0) rotate(-5deg);
	}

	50% {
		transform: translateY(-14px) rotate(4deg);
	}
}

.mgk-surface {
	background: rgba(3, 25, 42, 0.52);
	border: 1px solid rgba(115, 169, 209, 0.2);
	border-radius: 28px;
}

.mgk-entry-card {
	padding: clamp(24px, 3vw, 36px);
}

.mgk-page-title-wrap {
	gap: 2rem;
}

.mgk-page-title-surface {
	padding: 1.1rem 1.8rem;
	max-width: fit-content;
	margin-inline: auto;
}

.mgk-template-main--page {
	padding:
		0
		clamp(24px, 4vw, 48px)
		clamp(100px, 10vh, 130px);
}

.mgk-page-wrap {
	gap: clamp(32px, 5vh, 56px);
}

.mgk-page-wrap > p,
.mgk-page-wrap > .wp-block-shortcode,
.mgk-page-wrap > .wp-block-shortcode > p {
	margin: 0;
}

.mgk-page-header {
	position: relative;
	min-height: clamp(160px, 24vw, 200px);
	display: flex;
	align-items: flex-end;
	background-color: #000;
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
	border: 1px solid #0b4f7c;
	border-top: 0;
	border-radius: 0 0 18px 18px;
	overflow: hidden;
	box-shadow: none;
}

.mgk-page-header__overlay {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(0, 0, 0, 0.08) 0%, rgba(0, 0, 0, 0.42) 52%, rgba(0, 0, 0, 0.8) 100%),
		linear-gradient(90deg, rgba(0, 0, 0, 0.46) 0%, rgba(0, 0, 0, 0.12) 40%, rgba(0, 0, 0, 0.22) 100%);
	pointer-events: none;
}

.mgk-page-header__inner {
	position: relative;
	z-index: 1;
	width: 100%;
	padding: clamp(24px, 3vw, 34px);
}

.mgk-page-header__title {
	margin: 0;
	font-size: clamp(2.2rem, 4.4vw, 3.2rem);
	line-height: 1.02;
	letter-spacing: 0.02em;
	text-align: left;
}

.mgk-page-content {
	width: min(100%, 1310px);
	margin: 0 auto;
}

.mgk-page-content > * {
	margin-block-start: 0;
}

.mgk-page-content .wp-block-post-content {
	padding-inline: clamp(10px, 2vw, 20px);
}

.mgk-search-form .wp-block-search__inside-wrapper {
	border-radius: 999px;
	border: 1px solid rgba(115, 169, 209, 0.35);
	background: rgba(3, 25, 42, 0.4);
}

.mgk-search-form .wp-block-search__input {
	background: transparent;
	color: var(--wp--preset--color--space-text);
}

/* Forms migrated from the legacy mgkreacja theme. */
.wp-site-blocks form input[type="text"],
.wp-site-blocks form input[type="email"],
.wp-site-blocks form input[type="tel"],
.wp-site-blocks form input[type="url"],
.wp-site-blocks form input[type="password"],
.wp-site-blocks form input[type="search"],
.wp-site-blocks form input[type="number"],
.wp-site-blocks form input[type="range"],
.wp-site-blocks form input[type="date"],
.wp-site-blocks form input[type="month"],
.wp-site-blocks form input[type="week"],
.wp-site-blocks form input[type="time"],
.wp-site-blocks form input[type="datetime"],
.wp-site-blocks form input[type="datetime-local"],
.wp-site-blocks form input[type="color"],
.wp-site-blocks form select,
.wp-site-blocks form textarea,
.wpcf7 form input[type="text"],
.wpcf7 form input[type="email"],
.wpcf7 form input[type="tel"],
.wpcf7 form input[type="url"],
.wpcf7 form input[type="password"],
.wpcf7 form input[type="search"],
.wpcf7 form input[type="number"],
.wpcf7 form input[type="range"],
.wpcf7 form input[type="date"],
.wpcf7 form input[type="month"],
.wpcf7 form input[type="week"],
.wpcf7 form input[type="time"],
.wpcf7 form input[type="datetime"],
.wpcf7 form input[type="datetime-local"],
.wpcf7 form input[type="color"],
.wpcf7 form select,
.wpcf7 form textarea {
	color: #fff;
	font-family: "Michroma", sans-serif;
	background-color: transparent;
	border: 1px solid #076aaa;
	padding: 14px;
	border-radius: 10px;
	vertical-align: middle;
	width: 100%;
	font-size: 16px;
	transition: color 0.6s ease, border-color 0.6s ease, box-shadow 0.6s ease;
	box-sizing: border-box;
}

.wp-site-blocks form textarea,
.wpcf7 form textarea {
	font-family: "Michroma", sans-serif;
}

.wp-site-blocks form input[type="text"]:focus,
.wp-site-blocks form input[type="email"]:focus,
.wp-site-blocks form input[type="tel"]:focus,
.wp-site-blocks form input[type="url"]:focus,
.wp-site-blocks form input[type="password"]:focus,
.wp-site-blocks form input[type="search"]:focus,
.wp-site-blocks form input[type="number"]:focus,
.wp-site-blocks form input[type="date"]:focus,
.wp-site-blocks form select:focus,
.wp-site-blocks form textarea:focus,
.wpcf7 form input[type="text"]:focus,
.wpcf7 form input[type="email"]:focus,
.wpcf7 form input[type="tel"]:focus,
.wpcf7 form input[type="url"]:focus,
.wpcf7 form input[type="password"]:focus,
.wpcf7 form input[type="search"]:focus,
.wpcf7 form input[type="number"]:focus,
.wpcf7 form input[type="date"]:focus,
.wpcf7 form select:focus,
.wpcf7 form textarea:focus {
	background-color: transparent;
	border: 1px solid #55b4f3;
	box-shadow: 0 0 5px #256692, 0 0 7px #256692, 0 0 7px #256692;
	outline: none;
}

.wp-site-blocks form input::placeholder,
.wp-site-blocks form textarea::placeholder,
.wpcf7 form input::placeholder,
.wpcf7 form textarea::placeholder {
	font-size: 13px;
	color: #96caffa3;
}

.wp-site-blocks form input[type="checkbox"],
.wpcf7 form input[type="checkbox"] {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	width: 20px;
	height: 20px;
	min-width: 20px;
	flex: 0 0 20px;
	border: 1px solid #55b4f3;
	vertical-align: middle;
	border-radius: 4px;
	background-color: transparent;
	cursor: pointer;
	outline: none;
	position: relative;
}

.wp-site-blocks form input[type="checkbox"]:checked::before,
.wpcf7 form input[type="checkbox"]:checked::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 8px;
	height: 8px;
	background-color: red;
	border-radius: 1px;
	box-shadow: 0 0 5px red, 0 0 7px red, 0 0 7px red;
}

.wp-site-blocks form input[type="radio"],
.wpcf7 form input[type="radio"] {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	width: 20px;
	height: 20px;
	min-width: 20px;
	flex: 0 0 20px;
	border: 1px solid #55b4f3;
	border-radius: 50%;
	background-color: transparent;
	cursor: pointer;
	outline: none;
	position: relative;
	vertical-align: bottom;
}

.wp-site-blocks form input[type="radio"]:checked::before,
.wpcf7 form input[type="radio"]:checked::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 7px;
	height: 7px;
	background-color: red;
	border-radius: 50%;
	box-shadow: 0 0 5px red, 0 0 7px red, 0 0 7px red;
}

span.wpcf7-form-control.wpcf7-acceptance {
	float: left;
}

.wp-site-blocks form input[type="button"],
.wp-site-blocks form input[type="reset"],
.wp-site-blocks form input[type="submit"],
.wpcf7 form input[type="button"],
.wpcf7 form input[type="reset"],
.wpcf7 form input[type="submit"],
.wpcf7-submit,
.btn,
.reply a {
	background-color: #359dff34;
	border: 1px solid #60b0ff;
	font-family: "Michroma", sans-serif;
	border-radius: 999px;
	padding: 15px 45px;
	font-size: 13px;
	color: #6db7ff;
	transition: color 0.6s ease, background-color 0.6s ease, border-color 0.6s ease, box-shadow 0.6s ease;
}

.wp-site-blocks form input[type="button"]:hover,
.wp-site-blocks form input[type="button"]:focus,
.wp-site-blocks form input[type="reset"]:hover,
.wp-site-blocks form input[type="reset"]:focus,
.wp-site-blocks form input[type="submit"]:hover,
.wp-site-blocks form input[type="submit"]:focus,
.wpcf7-submit:hover,
.wpcf7-submit:focus {
	color: white;
	background-color: #359dff75;
	border: 1px solid #60b0ff;
	box-shadow: 0 0 5px #256692, 0 0 7px #256692, 0 0 7px #256692;
}

.wpcf7 form.sent .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output,
.wpcf7 form.spam .wpcf7-response-output,
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
	border-radius: 5px;
}

.cf7emailinput,
.cf7phoneinput {
	width: 100% !important;
}

.wpcf7-not-valid-tip {
	font-size: 0.8em;
	border-radius: 50px;
	border-top-left-radius: 0;
	color: #dc3232;
	border: 1px solid #dc3232;
	box-shadow: 3px 3px #dc3232;
	display: table;
	padding: 4px 12px;
	margin-top: 10px;
	margin-left: 7px;
	text-align: center;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
	color: #ffb900;
	border: 1px solid #ffb900;
	border-radius: 50px;
	box-shadow: 3px 3px #ffb900;
	padding: 8px 20px;
	text-align: center;
}

.wpcf7 form.sent .wpcf7-response-output {
	border-radius: 50px;
	color: #46b450;
	border: 1px solid #46b450;
	box-shadow: 3px 3px #46b450;
	padding: 8px 20px;
	text-align: center;
}

.wpcf7-checkbox {
	margin-top: 30px;
}

.wpcf7-list-item {
	display: block;
	margin: 1em 0 0 1em;
}

.wycena input[type="submit"] {
	float: right;
	margin-top: 50px;
}

.wyc-kont p {
	margin: 0;
	padding: 0;
}

/* --------------------- Contact form switcher --------------------- */

.mgk-contact-switcher {
	position: relative;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	margin: 0 0 clamp(22px, 3vw, 34px);
	padding: 10px;
	border: 1px solid rgba(115, 169, 209, 0.2);
	border-radius: 18px;
	background:
		linear-gradient(135deg, rgba(3, 25, 42, 0.84), rgba(1, 12, 24, 0.7)),
		radial-gradient(circle at 16% 20%, rgba(88, 188, 235, 0.18), transparent 34%),
		radial-gradient(circle at 82% 70%, rgba(255, 0, 0, 0.12), transparent 32%);
	box-shadow: inset 0 0 24px rgba(88, 188, 235, 0.05), 0 0 28px rgba(88, 188, 235, 0.08);
	overflow: hidden;
}

.mgk-contact-switcher::before {
	content: "";
	position: absolute;
	inset: 50% 16px auto;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(96, 176, 255, 0.42), transparent);
	pointer-events: none;
}

.wp-block-column:has(> .mgk-contact-switcher) {
	padding-top: clamp(14px, 2vw, 29px);
}

.mgk-contact-switcher__button {
	position: relative;
	box-sizing: border-box;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	min-width: 0;
	padding: 16px 16px 14px;
	border: 0;
	border-radius: 14px;
	background: transparent;
	color: var(--wp--preset--color--space-muted);
	font-family: "Michroma", sans-serif;
	font-size: 0.76rem;
	line-height: 1.2;
	cursor: pointer;
	transition: color 0.25s ease, transform 0.25s ease;
	z-index: 1;
}

.mgk-contact-switcher__button::before {
	content: "";
	position: absolute;
	inset: 4px;
	border: 1px solid rgba(96, 176, 255, 0);
	border-radius: 12px;
	background: rgba(2, 23, 40, 0);
	transition: border-color 0.25s ease, background 0.25s ease, box-shadow 0.25s ease;
	z-index: -1;
}

.mgk-contact-switcher__button:hover,
.mgk-contact-switcher__button:focus-visible {
	color: var(--wp--preset--color--space-text);
	outline: none;
	transform: translateY(-2px);
}

.mgk-contact-switcher__button:hover::before,
.mgk-contact-switcher__button:focus-visible::before {
	border-color: rgba(96, 176, 255, 0.28);
	background: rgba(53, 157, 255, 0.08);
	box-shadow: inset 0 0 18px rgba(88, 188, 235, 0.08);
}

.mgk-contact-switcher__button.is-active {
	color: var(--wp--preset--color--space-text);
	text-shadow: 0 0 12px rgba(234, 246, 255, 0.24);
}

.mgk-contact-switcher__button.is-active::before {
	border-color: rgba(255, 0, 0, 0.46);
	background: linear-gradient(180deg, rgba(255, 0, 0, 0.14), rgba(53, 157, 255, 0.1));
	box-shadow: inset 0 0 22px rgba(255, 0, 0, 0.08), 0 0 20px rgba(255, 0, 0, 0.12);
}

.mgk-contact-switcher__icon {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	flex: 0 0 34px;
	border: 1px solid rgba(115, 169, 209, 0.42);
	border-radius: 50%;
	background:
		radial-gradient(circle at 50% 50%, rgba(88, 188, 235, 0.2) 0 18%, transparent 19%),
		rgba(2, 23, 40, 0.82);
	box-shadow: 0 0 9px rgba(88, 188, 235, 0.16);
}

.mgk-contact-switcher__icon::before {
	content: "";
	position: absolute;
	inset: -5px;
	border: 1px solid rgba(96, 176, 255, 0.28);
	border-top-color: transparent;
	border-radius: 50%;
	transform: rotate(-28deg);
	transition: border-color 0.25s ease, transform 0.25s ease;
}

.mgk-contact-switcher__button.is-active .mgk-contact-switcher__icon {
	border-color: rgba(255, 0, 0, 0.72);
	background:
		radial-gradient(circle at 50% 50%, rgba(255, 0, 0, 0.92) 0 14%, transparent 16%),
		rgba(2, 23, 40, 0.82);
	box-shadow: 0 0 9px rgba(255, 0, 0, 0.42), 0 0 18px rgba(255, 0, 0, 0.22);
}

.mgk-contact-switcher__button.is-active .mgk-contact-switcher__icon::before {
	border-color: rgba(255, 0, 0, 0.5);
	border-top-color: transparent;
	transform: rotate(28deg);
}

.mgk-contact-switcher__label {
	overflow-wrap: anywhere;
}

.mgk-contact-form-panel.is-hidden,
.mgk-contact-form-panel[hidden] {
	display: none !important;
}

.astro3 {
	margin-top: 50px;
	animation: floatAndSwayAnimation 13s infinite ease-in-out alternate, astroFloat 22s infinite ease-in-out;
}

.mgk-contact-links {
	display: grid;
	gap: 10px;
	width: min(100%, 420px);
	margin: clamp(12px, 2vw, 22px) auto 0;
	padding: 0 !important;
	list-style: none;
}

.mgk-contact-links__item {
	position: static;
	margin: 0;
	padding: 0 !important;
	line-height: 1.35;
}

.mgk-contact-links__item::before {
	content: none !important;
	display: none !important;
}

.mgk-contact-links__link {
	display: grid;
	grid-template-columns: 38px minmax(0, 1fr);
	align-items: center;
	gap: 10px;
	color: var(--wp--preset--color--space-text);
	font-family: "Michroma", sans-serif;
	line-height: 1.35;
	letter-spacing: 0.02em;
	text-decoration: none;
	text-shadow: 0 0 10px rgba(88, 188, 235, 0.14);
	transition: color 0.25s ease, transform 0.25s ease, text-shadow 0.25s ease;
}

.mgk-contact-links__link:hover,
.mgk-contact-links__link:focus-visible {
	color: #ffffff;
	text-shadow: 0 0 10px rgba(88, 188, 235, 0.38);
	transform: translateX(4px);
	outline: none;
}

.mgk-contact-links__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
}

.mgk-contact-links__icon img {
	display: block;
	width: 100%;
	max-width: 22px;
	height: auto;
	filter: invert(66%) sepia(34%) saturate(656%) hue-rotate(172deg) brightness(101%) contrast(94%)
		drop-shadow(0 0 5px rgba(88, 188, 235, 0.32));
	transition: filter 0.25s ease, transform 0.25s ease;
}

.mgk-contact-links__link:hover .mgk-contact-links__icon img,
.mgk-contact-links__link:focus-visible .mgk-contact-links__icon img {
	filter: brightness(0) invert(1) drop-shadow(0 0 7px rgba(88, 188, 235, 0.7));
	transform: scale(1.06);
}

.mgk-contact-links strong,
.mgk-contact-links b {
	color: #ffffff;
	font-weight: 700;
}

/* --------------------- Offer masonry --------------------- */

.mgk-page-header,
.mgk-page-content,
.mgk-offer-masonry,
.mgk-masonry-faq,
.mgk-client-logos,
.mgk-portfolio-showcase,
.mgk-contact-links {
	content-visibility: auto;
	contain-intrinsic-size: auto 720px;
}

.mgk-contact-form-panel {
	overflow: visible;
}

.mgk-offer-masonry {
	width: min(100%, 1310px);
	margin: 0 auto;
	padding: clamp(18px, 3vw, 34px) 0 clamp(36px, 5vw, 72px);
}

.mgk-offer-masonry__intro {
	max-width: 860px;
	margin: 0 auto clamp(28px, 4vw, 48px);
	text-align: center;
}

.mgk-offer-masonry__eyebrow {
	margin: 0 0 12px;
	color: #58bceb;
	font-family: "Michroma", sans-serif;
	font-size: 0.72rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.mgk-offer-masonry__title {
	margin: 0;
	color: var(--wp--preset--color--space-text);
	font-size: clamp(1.55rem, 3vw, 2.35rem);
	line-height: 1.18;
}

.mgk-offer-masonry__lead {
	max-width: 760px;
	margin: 18px auto 0;
	color: var(--wp--preset--color--space-muted);
}

.mgk-offer-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	grid-auto-rows: minmax(clamp(310px, 24vw, 390px), auto);
	grid-auto-flow: dense;
	gap: clamp(14px, 1.6vw, 22px);
}

.mgk-offer-card {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	gap: clamp(14px, 1.5vw, 20px);
	min-height: 0;
	grid-column: span 1;
	grid-row: span 1;
	padding: clamp(20px, 2.2vw, 32px);
	border: 1px solid rgba(115, 169, 209, 0.2);
	border-radius: 18px;
	background:
		linear-gradient(145deg, rgba(3, 25, 42, 0.88), rgba(1, 12, 24, 0.74)),
		radial-gradient(circle at 18% 16%, rgba(88, 188, 235, 0.18), transparent 34%),
		radial-gradient(circle at 82% 88%, rgba(255, 0, 0, 0.1), transparent 32%);
	box-shadow: inset 0 0 18px rgba(88, 188, 235, 0.055);
	overflow: hidden;
	transition:
		border-color 0.42s cubic-bezier(0.22, 0.8, 0.24, 1),
		transform 0.42s cubic-bezier(0.22, 0.8, 0.24, 1),
		box-shadow 0.42s cubic-bezier(0.22, 0.8, 0.24, 1),
		background-color 0.42s ease;
}

.mgk-offer-card::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, transparent 0 18%, rgba(88, 188, 235, 0.08) 19%, transparent 20% 100%),
		linear-gradient(180deg, transparent 0 62%, rgba(88, 188, 235, 0.06) 63%, transparent 64% 100%);
	opacity: 0.42;
	mask-image: radial-gradient(circle at 70% 30%, #000 0 20%, transparent 58%);
	pointer-events: none;
	transform: scale(1);
	transition: opacity 0.46s ease, transform 0.52s cubic-bezier(0.22, 0.8, 0.24, 1);
}

.mgk-offer-card:hover,
.mgk-offer-card:focus-within {
	border-color: rgba(96, 176, 255, 0.56);
	box-shadow: inset 0 0 22px rgba(88, 188, 235, 0.08);
	transform: translateY(-4px);
}

.mgk-offer-card:hover::before,
.mgk-offer-card:focus-within::before {
	opacity: 0.66;
	transform: scale(1.035);
}

.mgk-offer-card--horizontal,
.mgk-offer-card--wide,
.mgk-offer-card--hero {
	grid-column: span 2;
	grid-row: span 1;
}

.mgk-offer-card--vertical,
.mgk-offer-card--tall {
	grid-column: span 1;
	grid-row: span 2;
}

.mgk-offer-card--hero {
	background:
		linear-gradient(145deg, rgba(3, 25, 42, 0.78), rgba(1, 12, 24, 0.7)),
		radial-gradient(circle at 24% 22%, rgba(88, 188, 235, 0.22), transparent 36%),
		radial-gradient(circle at 78% 78%, rgba(255, 0, 0, 0.14), transparent 34%);
}

.mgk-offer-card--horizontal {
	display: grid;
	grid-template-columns:
		minmax(0, calc(100% - var(--mgk-offer-media-share, 50%)))
		minmax(0, var(--mgk-offer-media-share, 50%));
	grid-template-areas:
		"header media"
		"body media";
	align-items: stretch;
	column-gap: clamp(16px, 2vw, 28px);
	row-gap: clamp(14px, 1.5vw, 20px);
}

.mgk-offer-card--vertical {
	display: flex;
	flex-direction: column;
	gap: clamp(14px, 1.6vw, 22px);
}

.mgk-offer-card__header {
	position: static;
	grid-area: header;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
	padding-right: 46px;
	min-height: 40px;
}

.mgk-offer-card__icon {
	position: relative;
	z-index: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	flex: 0 0 40px;
}

.mgk-offer-card__icon img {
	display: block;
	width: 32px;
	max-height: 32px;
	filter: invert(66%) sepia(34%) saturate(656%) hue-rotate(172deg) brightness(101%) contrast(94%);
	transition: filter 0.38s ease, transform 0.42s cubic-bezier(0.22, 0.8, 0.24, 1);
}

.mgk-offer-card:hover .mgk-offer-card__icon img,
.mgk-offer-card:focus-within .mgk-offer-card__icon img {
	filter: brightness(0) invert(1);
	transform: translateY(-2px) scale(1.04);
}

.mgk-offer-card__index {
	position: absolute;
	z-index: 4;
	top: 20px;
	right: 20px;
	color: rgba(88, 188, 235, 0.26);
	font-family: "Michroma", sans-serif;
	font-size: 0.68rem;
	letter-spacing: 0.18em;
	pointer-events: none;
}

.mgk-offer-card__body {
	position: relative;
	z-index: 1;
	grid-area: body;
	min-width: 0;
	margin-top: 0;
}

.mgk-offer-card--vertical .mgk-offer-card__header {
	order: 2;
}

.mgk-offer-card--vertical .mgk-offer-card__body {
	order: 3;
	flex: 1 1 auto;
}

.mgk-offer-card__media {
	position: relative;
	z-index: 1;
	grid-area: media;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: clamp(92px, 10vw, 150px);
	max-height: clamp(120px, 12vw, 190px);
	margin: clamp(8px, 1.6vw, 18px) 0;
	overflow: visible;
	border-radius: 0;
	background: transparent;
}

.mgk-offer-card--horizontal .mgk-offer-card__media,
.mgk-offer-card--vertical .mgk-offer-card__media {
	min-height: 0;
	max-height: none;
	margin: 0;
}

.mgk-offer-card--horizontal .mgk-offer-card__media {
	height: 100%;
}

.mgk-offer-card--vertical .mgk-offer-card__media {
	order: 1;
	height: auto;
	flex: 0 0 var(--mgk-offer-media-share, 50%);
	min-height: 0;
}

.mgk-offer-card__media img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: none;
	transition: transform 0.55s cubic-bezier(0.22, 0.8, 0.24, 1);
}

.mgk-offer-card:hover .mgk-offer-card__media img,
.mgk-offer-card:focus-within .mgk-offer-card__media img {
	transform: scale(1.018);
}

.mgk-offer-card__title {
	margin: 0 0 12px;
	color: var(--wp--preset--color--space-text);
	font-family: "Michroma", sans-serif;
	font-size: clamp(0.95rem, 1.35vw, 1.18rem);
	line-height: 1.22;
}

.mgk-offer-card--hero .mgk-offer-card__title {
	font-size: clamp(1.18rem, 2vw, 1.72rem);
}

.mgk-offer-card__text,
.mgk-offer-card__text p {
	margin: 0;
	color: var(--wp--preset--color--space-muted);
	font-size: 0.8rem;
	line-height: 1.52;
	overflow-wrap: anywhere;
}

.mgk-offer-card__text p + p {
	margin-top: 0.7em;
}

.mgk-offer-actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: clamp(14px, 2vw, 24px);
	margin-top: clamp(30px, 4.5vw, 64px);
}

.mgk-cosmic-button {
	position: relative;
	isolation: isolate;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: min(100%, 260px);
	padding: 18px 34px;
	border: 1px solid rgba(96, 176, 255, 0.74);
	border-radius: 999px;
	color: var(--wp--preset--color--space-muted);
	font-family: "Michroma", sans-serif;
	font-size: clamp(0.78rem, 1vw, 0.94rem);
	line-height: 1.2;
	text-align: center;
	text-decoration: none;
	background:
		linear-gradient(135deg, rgba(53, 157, 255, 0.22), rgba(2, 23, 40, 0.66)),
		radial-gradient(circle at 50% 50%, rgba(88, 188, 235, 0.2), transparent 58%);
	box-shadow: inset 0 0 18px rgba(88, 188, 235, 0.09), 0 0 22px rgba(88, 188, 235, 0.12);
	overflow: hidden;
	transition: color 0.25s ease, border-color 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
}

.mgk-cosmic-button::before {
	content: "";
	position: absolute;
	inset: -1px;
	z-index: -1;
	background: linear-gradient(90deg, transparent, rgba(96, 176, 255, 0.28), transparent);
	transform: translateX(-110%);
	transition: transform 0.55s ease;
}

.mgk-cosmic-button:hover,
.mgk-cosmic-button:focus-visible {
	color: var(--wp--preset--color--space-text);
	border-color: rgba(234, 246, 255, 0.9);
	box-shadow: inset 0 0 18px rgba(88, 188, 235, 0.14), 0 0 28px rgba(88, 188, 235, 0.22);
	transform: translateY(-3px);
	outline: none;
}

.mgk-cosmic-button:hover::before,
.mgk-cosmic-button:focus-visible::before {
	transform: translateX(110%);
}

.mgk-cosmic-button--primary {
	border-color: rgba(255, 0, 0, 0.58);
	background:
		linear-gradient(135deg, rgba(255, 0, 0, 0.16), rgba(53, 157, 255, 0.18)),
		radial-gradient(circle at 50% 50%, rgba(255, 0, 0, 0.16), transparent 58%);
	box-shadow: inset 0 0 18px rgba(255, 0, 0, 0.08), 0 0 22px rgba(255, 0, 0, 0.1);
}

.mgk-cosmic-button--primary:hover,
.mgk-cosmic-button--primary:focus-visible {
	border-color: rgba(255, 0, 0, 0.84);
	box-shadow: inset 0 0 18px rgba(255, 0, 0, 0.12), 0 0 30px rgba(255, 0, 0, 0.2);
}

.mgk-masonry-faq,
.mgk-client-logos {
	width: min(100%, 1310px);
	margin: clamp(48px, 6vw, 88px) auto 0;
}

.mgk-masonry-section__eyebrow {
	margin: 0 0 12px;
	color: #58bceb;
	font-family: "Michroma", sans-serif;
	font-size: 0.7rem;
	letter-spacing: 0.18em;
	text-align: center;
	text-transform: uppercase;
}

.mgk-masonry-section__title {
	margin: 0 auto clamp(24px, 3.4vw, 42px);
	max-width: 820px;
	color: var(--wp--preset--color--space-text);
	font-family: "Michroma", sans-serif;
	font-size: clamp(1.35rem, 2.8vw, 2.45rem);
	line-height: 1.18;
	text-align: center;
}

.mgk-masonry-faq__items {
	display: grid;
	gap: clamp(8px, 1vw, 14px);
}

.mgk-faq-item {
	position: relative;
	border: 1px solid rgba(115, 169, 209, 0.22);
	border-radius: 18px;
	background:
		linear-gradient(145deg, rgba(3, 25, 42, 0.86), rgba(1, 12, 24, 0.72)),
		radial-gradient(circle at 12% 22%, rgba(88, 188, 235, 0.12), transparent 34%);
	box-shadow: inset 0 0 22px rgba(88, 188, 235, 0.04), 0 0 24px rgba(88, 188, 235, 0.07);
	overflow: hidden;
	transition:
		border-color 0.42s cubic-bezier(0.22, 0.8, 0.24, 1),
		box-shadow 0.42s cubic-bezier(0.22, 0.8, 0.24, 1);
}

.mgk-faq-item[open] {
	border-color: rgba(234, 246, 255, 0.46);
	box-shadow: inset 0 0 24px rgba(234, 246, 255, 0.05), 0 0 28px rgba(234, 246, 255, 0.12);
}

.mgk-faq-item__summary {
	position: relative;
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	align-items: center;
	gap: clamp(8px, 1.6vw, 12px);
	min-height: 0;
	padding: clamp(8px, 0.9vw, 12px) clamp(50px, 4vw, 62px) clamp(8px, 0.9vw, 12px) clamp(14px, 1.4vw, 20px);
	color: #58bceb;
	cursor: pointer;
	list-style: none;
	transition: color 0.36s ease, padding 0.42s cubic-bezier(0.22, 0.8, 0.24, 1);
}

.mgk-faq-item__summary::-webkit-details-marker {
	display: none;
}

.mgk-faq-item__index {
	color: rgba(88, 188, 235, 0.26);
	font-family: "Michroma", sans-serif;
	font-size: 0.62rem;
	letter-spacing: 0.18em;
}

.mgk-faq-item__question {
	color: #58bceb;
	font-family: "Michroma", sans-serif;
	font-size: clamp(0.9rem, 1.2vw, 1.1rem);
	line-height: 1.35;
	text-align: left;
	transition: color 0.36s ease;
}

.mgk-faq-item[open] .mgk-faq-item__question {
	color: #ffffff;
}

.mgk-faq-item__toggle {
	position: absolute;
	top: 50%;
	right: clamp(14px, 1.4vw, 20px);
	transform: translateY(-50%);
	width: 28px;
	height: 28px;
	border: 1px solid rgba(96, 176, 255, 0.46);
	border-radius: 50%;
	box-shadow: 0 0 14px rgba(88, 188, 235, 0.12);
	transition: border-color 0.36s ease, box-shadow 0.36s ease, transform 0.42s cubic-bezier(0.22, 0.8, 0.24, 1);
}

.mgk-faq-item__toggle::before,
.mgk-faq-item__toggle::after {
	content: "";
	position: absolute;
	inset: 50% auto auto 50%;
	width: 12px;
	height: 2px;
	background: #58bceb;
	transform: translate(-50%, -50%);
	transition: transform 0.42s cubic-bezier(0.22, 0.8, 0.24, 1), background 0.36s ease;
}

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

.mgk-faq-item[open] .mgk-faq-item__toggle {
	border-color: rgba(234, 246, 255, 0.78);
	box-shadow: 0 0 18px rgba(234, 246, 255, 0.18);
}

.mgk-faq-item[open] .mgk-faq-item__toggle::before,
.mgk-faq-item[open] .mgk-faq-item__toggle::after {
	background: #ffffff;
}

.mgk-faq-item[open] .mgk-faq-item__toggle::after {
	transform: translate(-50%, -50%) rotate(0deg);
}

.mgk-faq-item__content {
	display: grid;
	grid-template-rows: 0fr;
	padding: 0 clamp(14px, 1.4vw, 20px);
	color: #58bceb;
	font-size: 0.86rem;
	line-height: 1.6;
	transition:
		grid-template-rows 0.46s cubic-bezier(0.22, 0.8, 0.24, 1),
		padding-bottom 0.46s cubic-bezier(0.22, 0.8, 0.24, 1);
}

.mgk-faq-item[open] .mgk-faq-item__content {
	grid-template-rows: 1fr;
	padding-bottom: clamp(8px, 0.9vw, 12px);
}

.mgk-faq-item__content-inner {
	min-height: 0;
	overflow: hidden;
}

.mgk-faq-item__content p {
	margin: 0;
}

.mgk-faq-item__content p + p {
	margin-top: 0.75em;
}

.mgk-faq-item__content strong,
.mgk-faq-item__content b {
	color: var(--wp--preset--color--space-text);
	font-weight: 700;
}

.mgk-faq-item__content del,
.mgk-faq-item__content s {
	opacity: 0.68;
	text-decoration-color: rgba(234, 246, 255, 0.72);
	text-decoration-thickness: 1px;
}

.mgk-faq-item__content ul,
.mgk-faq-item__content ol {
	margin: 0.7em 0 0 !important;
	margin-inline-start: 14px !important;
	padding-inline-start: 0 !important;
	color: inherit;
}

.mgk-faq-item__content li {
	margin: 0.28em 0 !important;
	padding-inline-start: 24px !important;
	color: inherit;
}

.mgk-client-logos__viewport {
	position: relative;
	width: 100%;
	margin-top: calc(clamp(12px, 1.4vw, 20px) * -1);
	padding-top: clamp(12px, 1.4vw, 20px);
	overflow: hidden;
	mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}

.mgk-client-logos__track {
	display: flex;
	gap: 0;
	width: max-content;
	animation: mgk-client-logos-marquee 42s linear infinite;
	will-change: transform;
	transform: translate3d(0, 0, 0);
}

.mgk-client-logos__set {
	display: grid;
	grid-auto-flow: column;
	grid-template-rows: repeat(3, minmax(0, 1fr));
	grid-auto-columns: clamp(150px, 11.5vw, 210px);
	gap: clamp(12px, 1.5vw, 20px);
	padding-right: clamp(12px, 1.5vw, 20px);
	flex: 0 0 auto;
}

.mgk-client-logo {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 3 / 2;
	min-height: 0;
	margin: 0;
	padding: clamp(18px, 2vw, 28px);
	border: 1px solid rgba(115, 169, 209, 0.14);
	border-radius: 16px;
	background: transparent;
	box-shadow: none;
	transition: border-color 0.2s ease;
}

.mgk-client-logo:hover {
	border-color: rgba(234, 246, 255, 0.34);
}

.mgk-client-logo img {
	display: block;
	width: auto;
	max-width: 92%;
	max-height: clamp(58px, 5vw, 78px);
	opacity: 0.92;
	filter: brightness(0) saturate(100%) invert(94%) sepia(8%) saturate(430%) hue-rotate(174deg) brightness(104%) contrast(101%);
	transition: opacity 0.25s ease, filter 0.25s ease;
}

.mgk-client-logo:hover img {
	opacity: 1;
	filter: brightness(0) saturate(100%) invert(96%) sepia(8%) saturate(350%) hue-rotate(174deg) brightness(108%) contrast(104%);
}

@keyframes mgk-client-logos-marquee {
	to {
		transform: translate3d(-50%, 0, 0);
	}
}

@media (prefers-reduced-motion: reduce) {
	.mgk-client-logos__track {
		animation: none;
	}
}

.mgk-offer-masonry__empty {
	color: var(--wp--preset--color--space-muted);
	text-align: center;
}

.mgk-offer-masonry__cta {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 14px;
	margin-top: clamp(28px, 4vw, 46px);
}

@media (max-width: 980px) {
	.mgk-offer-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		grid-auto-rows: minmax(260px, auto);
	}

	.mgk-offer-card,
	.mgk-offer-card--wide,
	.mgk-offer-card--hero,
	.mgk-offer-card--horizontal,
	.mgk-offer-card--vertical,
	.mgk-offer-card--tall {
		display: flex;
		flex-direction: column;
		grid-column: span 1;
		grid-row: span 1;
		min-height: 260px;
	}

	.mgk-offer-card--horizontal .mgk-offer-card__media,
	.mgk-offer-card--vertical .mgk-offer-card__media {
		min-height: clamp(140px, 28vw, 220px);
		height: auto;
	}
}

@media (max-width: 640px) {
	.mgk-offer-grid {
		grid-template-columns: 1fr;
	}

	.mgk-offer-actions {
		align-items: center;
		flex-direction: column;
		gap: 14px;
		margin-top: 28px;
		padding-inline: 12px;
	}

	.mgk-cosmic-button,
	.mgk-offer-actions .mgk-cosmic-button,
	.mgk-portfolio-slide__buttons .mgk-cosmic-button {
		box-sizing: border-box;
		width: min(100%, 420px);
		min-width: 0;
		padding: 13px 20px;
		font-size: 0.72rem;
	}

	.mgk-offer-card,
	.mgk-offer-card--hero,
	.mgk-offer-card--tall {
		min-height: 0;
	}
}

@keyframes floatAndSwayAnimation {
	0% {
		transform: translateY(0) rotate(0deg);
	}

	100% {
		transform: translateY(-40px) rotate(0deg);
	}
}

@keyframes astroFloat {
	0%,
	100% {
		transform: translateY(0) rotate(0deg);
	}

	50% {
		transform: translateY(-50px) rotate(-15deg);
	}
}

/* --------------------- Wycena tabs --------------------- */

/* fix: WP is-layout-constrained narzuca max-width na bloki CF7 —
   nadpisujemy przez klasy dodane przez nasz JS (wyższy priorytet) */
.wp-block-column .mgk-contact-form-panel--quote,
.wp-block-column .mgk-contact-form-panel--contact {
	width: 100% !important;
	max-width: none !important;
	margin-inline: 0 !important;
}

.wp-block-column .mgk-contact-form-panel--quote .wpcf7,
.wp-block-column .mgk-contact-form-panel--quote .wpcf7 form,
.wp-block-column .mgk-contact-form-panel--contact .wpcf7,
.wp-block-column .mgk-contact-form-panel--contact .wpcf7 form {
	width: 100% !important;
	max-width: none !important;
	box-sizing: border-box;
}

.wp-block-contact-form-7-contact-form-selector:has(.grid.wycena),
.wp-block-contact-form-7-contact-form-selector:has(.mgk-quote-form) {
	width: 100%;
	max-width: none !important;
	margin-inline: 0 !important;
	overflow: visible;
}

/* fix: usuń padding-inline z post-content zawierającego przełącznik formularzy,
   żeby działało także na tłumaczeniach strony kontaktowej */
.mgk-page-content:has(.mgk-contact-switcher) .wp-block-post-content {
	padding-inline: 0;
}

.wpcf7 form .grid.wycena,
.wpcf7 form .mgk-quote-form {
	display: grid;
	grid-template-columns: minmax(140px, 160px) minmax(0, 1fr);
	gap: clamp(12px, 1.8vw, 22px);
	align-items: start;
	margin: clamp(18px, 3vw, 34px) 0 0;
	overflow: visible;
}

.mgk-contact-form-panel--quote .wpcf7 form .grid.wycena,
.mgk-contact-form-panel--quote .wpcf7 form .mgk-quote-form {
	margin-top: 0;
}

.wpcf7 form .grid.wycena .col-3,
.wpcf7 form .grid.wycena .col-9,
.wpcf7 form .grid.wycena .col-12,
.wpcf7 form .grid.wycena .col-6_sm-12,
.wpcf7 form .mgk-quote-steps,
.wpcf7 form .mgk-quote-content,
.wpcf7 form .mgk-quote-field {
	min-width: 0;
}

.wpcf7 form .tab-navigation,
.wpcf7 form .mgk-quote-steps {
	position: sticky;
	top: clamp(96px, 12vh, 132px);
	display: flex;
	flex-direction: column;
	gap: 18px;
	width: calc(100% - 16px);
	margin-left: 16px;
	padding-left: 0;
	overflow: visible;
}

.wpcf7 form .tab-navigation p,
.wpcf7 form .mgk-quote-steps p {
	display: contents;
	margin: 0;
}

.wpcf7 form .tab-navigation br,
.wpcf7 form .mgk-quote-steps br,
.wpcf7 form .tab-button br {
	display: none;
}

.wpcf7 form .mgk-quote-content {
	width: 100%;
}

.wpcf7 form .tab-button {
	position: relative;
	display: grid;
	grid-template-columns: 34px minmax(0, 1fr);
	align-items: center;
	gap: 10px;
	width: 100%;
	padding: 8px 10px;
	border: 1px solid rgba(96, 176, 255, 0.28);
	border-radius: 999px;
	background: rgba(1, 12, 24, 0.54);
	color: var(--wp--preset--color--space-muted);
	font-family: "Michroma", sans-serif;
	text-align: left;
	cursor: pointer;
	transition: border-color 0.25s ease, box-shadow 0.25s ease, color 0.25s ease, transform 0.25s ease;
}

.wpcf7 form .tab-button:hover,
.wpcf7 form .tab-button:focus-visible {
	border-color: rgba(96, 176, 255, 0.74);
	box-shadow: 0 0 16px rgba(88, 188, 235, 0.18);
	color: var(--wp--preset--color--space-text);
	outline: none;
	transform: translateX(4px);
}

.wpcf7 form .tab-button.active {
	border-color: rgba(255, 0, 0, 0.72);
	color: var(--wp--preset--color--space-text);
	box-shadow: 0 0 12px rgba(255, 0, 0, 0.24), 0 0 22px rgba(88, 188, 235, 0.14);
	animation: mgk-quote-tab-pulse 1.35s ease-out infinite;
}

.wpcf7 form .tab-button .krok {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	flex: 0 0 28px;
	border-radius: 50%;
	background: rgba(2, 23, 40, 0.8);
	color: var(--wp--preset--color--space-muted);
	border: 1px solid rgba(115, 169, 209, 0.48);
	box-shadow: 0 0 9px rgba(88, 188, 235, 0.18);
	font-size: 0.76rem;
	line-height: 1;
}

.wpcf7 form .tab-button .krok-opis {
	display: inline-block;
	min-width: 0;
	color: var(--wp--preset--color--space-muted);
	font-size: 0.78rem;
	line-height: 1.2;
	text-shadow: none;
	white-space: normal;
}

.wpcf7 form .tab-button.active .krok-opis {
	color: var(--wp--preset--color--space-text);
}

.wpcf7 form .tab-button.active .krok {
	color: #ff0000;
	border-color: rgba(255, 0, 0, 0.72);
	box-shadow: 0 0 9px rgba(255, 0, 0, 0.44), 0 0 16px rgba(255, 0, 0, 0.2);
}

.wpcf7 form .tab-container {
	position: relative;
	padding: clamp(22px, 3vw, 34px);
	border: 1px solid rgba(115, 169, 209, 0.22);
	border-radius: 16px;
	background: rgba(3, 25, 42, 0.46);
	box-shadow: 0 0 32px rgba(88, 188, 235, 0.08);
	overflow: visible;
}

.wpcf7 form .tab {
	display: block;
}

.wpcf7 form .tab.hidden {
	display: none !important;
}

.wpcf7 form .tab h3 {
	margin-top: 0;
	margin-bottom: clamp(18px, 2vw, 28px);
	color: var(--wp--preset--color--space-text);
}

.wpcf7 form .tab p {
	margin: 0 0 1rem;
}

.wpcf7 form .tab .grid,
.wpcf7 form .mgk-quote-fields {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px 22px;
}

.wpcf7 form .tab .grid.wyc-kont,
.wpcf7 form .mgk-quote-fields--contact {
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px 22px;
	align-items: start;
}

.wpcf7 form .tab .grid.wyc-kont > .col-12,
.wpcf7 form .mgk-quote-field--full {
	grid-column: 1 / -1;
}

.wpcf7 form .tab .grid.wyc-kont textarea,
.wpcf7 form .mgk-quote-fields--contact textarea {
	min-height: 150px;
}

.wpcf7 form .tab .grid.wyc-kont .wpcf7-acceptance,
.wpcf7 form .mgk-quote-acceptance .wpcf7-acceptance {
	float: none;
	display: inline-flex;
	margin-right: 10px;
	vertical-align: top;
}

.wpcf7 form .tab .grid.wyc-kont .wpcf7-acceptance .wpcf7-list-item,
.wpcf7 form .mgk-quote-acceptance .wpcf7-acceptance .wpcf7-list-item {
	display: inline-flex;
}

.wpcf7 form .tab .grid.wyc-kont a,
.wpcf7 form .mgk-quote-acceptance a {
	color: var(--wp--preset--color--space-text);
}

.wpcf7 form #tab-3 > p:last-child,
.wpcf7 form .mgk-quote-actions {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	margin-top: clamp(26px, 4vw, 46px);
}

.wpcf7 form .tab p:has(> .prev-tab):has(> .next-tab),
.wpcf7 form .mgk-quote-actions > p {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	width: 100%;
	margin: 0;
}

.wpcf7 form .tab p:has(> .prev-tab):has(> .next-tab) br,
.wpcf7 form .mgk-quote-actions br {
	display: none;
}

.wpcf7 form #tab-3 > p:last-child .prev-tab,
.wpcf7 form #tab-3 > p:last-child .wpcf7-submit,
.wpcf7 form .tab p:has(> .prev-tab):has(> .next-tab) .prev-tab,
.wpcf7 form .tab p:has(> .prev-tab):has(> .next-tab) .next-tab,
.wpcf7 form .mgk-quote-actions .prev-tab,
.wpcf7 form .mgk-quote-actions .wpcf7-submit {
	margin-top: 0;
	margin-right: 0;
	padding-left: 20px;
	padding-right: 20px;
}

.wpcf7 form #tab-3 > p:last-child .wpcf7-submit,
.wpcf7 form .tab p:has(> .prev-tab):has(> .next-tab) .prev-tab,
.wpcf7 form .tab p:has(> .prev-tab):has(> .next-tab) .next-tab,
.wpcf7 form .mgk-quote-actions .prev-tab,
.wpcf7 form .mgk-quote-actions .wpcf7-submit {
	width: auto;
	max-width: 100%;
	text-align: center;
	white-space: nowrap;
}

.wpcf7 form #tab-3 > p:last-child .prev-tab,
.wpcf7 form .tab p:has(> .prev-tab):has(> .next-tab) .prev-tab,
.wpcf7 form .mgk-quote-actions .prev-tab {
	min-width: clamp(150px, 20vw, 180px);
}

.wpcf7 form #tab-3 > p:last-child .wpcf7-submit,
.wpcf7 form .tab p:has(> .prev-tab):has(> .next-tab) .next-tab,
.wpcf7 form .mgk-quote-actions .wpcf7-submit {
	min-width: clamp(190px, 28vw, 235px);
	margin-left: auto;
}

.wpcf7 form #tab-3 > p:last-child .wpcf7-spinner,
.wpcf7 form .mgk-quote-actions .wpcf7-spinner {
	position: absolute;
	right: 0;
	bottom: -30px;
	margin: 0;
}

.wpcf7 form .grid.wycena .wpcf7-checkbox,
.wpcf7 form .grid.wycena .wpcf7-radio,
.wpcf7 form .mgk-quote-form .wpcf7-checkbox,
.wpcf7 form .mgk-quote-form .wpcf7-radio {
	display: grid;
	gap: 12px;
	margin-top: 16px;
}

.wpcf7 form .grid.wycena .wpcf7-list-item,
.wpcf7 form .mgk-quote-form .wpcf7-list-item {
	margin: 0;
}

.wpcf7 form .grid.wycena .wpcf7-list-item label,
.wpcf7 form .mgk-quote-form .wpcf7-list-item label {
	display: inline-flex;
	align-items: flex-start;
	gap: 10px;
	color: var(--wp--preset--color--space-muted);
	line-height: 1.5;
}

.wpcf7 form .grid.wycena input[type="checkbox"],
.wpcf7 form .grid.wycena input[type="radio"],
.wpcf7 form .mgk-quote-form input[type="checkbox"],
.wpcf7 form .mgk-quote-form input[type="radio"] {
	margin-top: 0.22em;
}

.wpcf7 form .next-tab,
.wpcf7 form .prev-tab {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 22px;
	margin-right: 12px;
	padding: 12px 28px;
	border: 1px solid #60b0ff;
	border-radius: 999px;
	background: rgba(53, 157, 255, 0.2);
	color: #6db7ff;
	font-family: "Michroma", sans-serif;
	font-size: 0.78rem;
	cursor: pointer;
	transition: color 0.25s ease, background 0.25s ease, box-shadow 0.25s ease;
}

.wpcf7 form .next-tab:hover,
.wpcf7 form .next-tab:focus-visible,
.wpcf7 form .prev-tab:hover,
.wpcf7 form .prev-tab:focus-visible {
	color: #ffffff;
	background: rgba(53, 157, 255, 0.46);
	box-shadow: 0 0 5px #256692, 0 0 7px #256692, 0 0 7px #256692;
	outline: none;
}

@keyframes mgk-quote-tab-pulse {
	0% {
		box-shadow: 0 0 0 0 rgba(255, 0, 0, 0.34), 0 0 14px rgba(88, 188, 235, 0.12);
	}

	70% {
		box-shadow: 0 0 0 12px rgba(255, 0, 0, 0), 0 0 20px rgba(88, 188, 235, 0.18);
	}

	100% {
		box-shadow: 0 0 0 0 rgba(255, 0, 0, 0), 0 0 14px rgba(88, 188, 235, 0.12);
	}
}

/* fix pełnej szerokości wrapperów formularza wyceny */
.wp-block-contact-form-7-contact-form-selector:has(.grid.wycena) .wpcf7,
.wp-block-contact-form-7-contact-form-selector:has(.grid.wycena) .wpcf7 form,
.wp-block-contact-form-7-contact-form-selector:has(.mgk-quote-form) .wpcf7,
.wp-block-contact-form-7-contact-form-selector:has(.mgk-quote-form) .wpcf7 form {
	width: 100%;
	box-sizing: border-box;
	overflow: visible;
}

/* --------------------- Formularz kontaktowy (ramka) --------------------- */

.mgk-contact-form-panel--contact {
	width: 100%;
	max-width: none !important;
	margin-inline: 0 !important;
	box-sizing: border-box;
}

.mgk-contact-form-panel--contact .wpcf7 {
	width: 100%;
}

.mgk-contact-form-panel--contact .wpcf7 form {
	position: relative;
	padding: clamp(22px, 3vw, 34px);
	border: 1px solid rgba(115, 169, 209, 0.22);
	border-radius: 16px;
	background: rgba(3, 25, 42, 0.46);
	box-shadow: 0 0 32px rgba(88, 188, 235, 0.08);
	width: 100%;
	box-sizing: border-box;
}

.mgk-contact-form-panel--contact .wpcf7 form p {
	margin: 0;
}

.mgk-contact-form {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: clamp(14px, 1.7vw, 22px);
}

.mgk-contact-form__field,
.mgk-contact-form__acceptance,
.mgk-contact-form__actions {
	min-width: 0;
}

.mgk-contact-form__field--full,
.mgk-contact-form__acceptance,
.mgk-contact-form__actions {
	grid-column: 1 / -1;
}

.mgk-contact-form__field label,
.mgk-contact-form__field .wpcf7-form-control-wrap {
	display: block;
	width: 100%;
}

.mgk-contact-form textarea {
	min-height: clamp(210px, 24vw, 360px);
}

.mgk-contact-form__acceptance {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-top: clamp(6px, 1vw, 12px);
	color: var(--wp--preset--color--space-muted);
	line-height: 1.55;
}

.mgk-contact-form__acceptance .wpcf7-acceptance {
	float: none;
	display: inline-flex;
	flex: 0 0 auto;
	margin: 0;
}

.mgk-contact-form__acceptance .wpcf7-list-item {
	display: inline-flex;
	margin: 0;
}

.mgk-contact-form__acceptance a {
	color: var(--wp--preset--color--space-text);
}

.mgk-contact-form__actions {
	display: flex;
	justify-content: flex-end;
	margin-top: clamp(6px, 1vw, 12px);
}

.mgk-contact-form__actions .wpcf7-submit {
	margin: 0;
}

.mgk-contact-form-panel--contact .wpcf7 form .grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px 22px;
}

.mgk-contact-form-panel--contact .wpcf7 form .grid .col-12 {
	grid-column: 1 / -1;
}

.mgk-contact-form-panel--contact .wpcf7 form textarea {
	min-height: 150px;
}

.mgk-contact-form-panel--contact .wpcf7 form input[type="submit"] {
	float: none;
	margin-top: 0;
	display: block;
	margin-left: auto;
}

@media (max-width: 900px) {
	.mgk-scroll-overlay-top {
		display: none;
	}

	.mgk-contact-switcher {
		width: 100%;
		gap: 8px;
		padding: 8px;
		border-radius: 14px;
		margin-bottom: 22px;
	}

	.mgk-contact-switcher__button {
		gap: 8px;
		padding: 12px 10px;
		font-size: 0.7rem;
	}

	.mgk-contact-switcher__icon {
		width: 28px;
		height: 28px;
		flex-basis: 28px;
	}

	.wpcf7 form .grid.wycena,
	.wpcf7 form .mgk-quote-form {
		grid-template-columns: 1fr;
		gap: 22px;
	}

	.mgk-contact-form-panel--contact .wpcf7 form .grid {
		grid-template-columns: 1fr;
	}

	.mgk-contact-form {
		grid-template-columns: 1fr;
	}

	.mgk-contact-form__actions {
		justify-content: stretch;
	}

	.mgk-contact-form__actions .wpcf7-submit {
		width: 100%;
	}

	.wpcf7 form .tab-navigation,
	.wpcf7 form .mgk-quote-steps {
		position: static;
		display: grid;
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 10px;
		width: 100%;
		margin-left: 0;
		padding-left: 0;
	}

	.wpcf7 form .tab-button {
		grid-template-columns: 1fr;
		justify-items: center;
		gap: 8px;
		padding: 10px 8px;
		text-align: center;
	}

	.wpcf7 form .tab-button:hover,
	.wpcf7 form .tab-button:focus-visible {
		transform: translateY(-2px);
	}

	.wpcf7 form .tab-container {
		min-height: 0;
		padding: 22px 18px;
	}

	.wpcf7 form .tab .grid,
	.wpcf7 form .mgk-quote-fields {
		grid-template-columns: 1fr;
	}

	.wpcf7 form .tab .grid.wyc-kont,
	.wpcf7 form .mgk-quote-fields--contact {
		grid-template-columns: 1fr;
	}

	.wpcf7 form #tab-3 > p:last-child,
	.wpcf7 form .mgk-quote-actions {
		align-items: stretch;
		flex-direction: column;
	}

	.wpcf7 form .tab p:has(> .prev-tab):has(> .next-tab),
	.wpcf7 form .mgk-quote-actions > p {
		align-items: stretch;
		flex-direction: column;
	}

	.wpcf7 form #tab-3 > p:last-child .prev-tab,
	.wpcf7 form #tab-3 > p:last-child .wpcf7-submit,
	.wpcf7 form .mgk-quote-actions .prev-tab,
	.wpcf7 form .mgk-quote-actions .wpcf7-submit {
		width: 100%;
	}

	.wp-site-blocks::after {
		background:
			linear-gradient(180deg, rgba(0, 0, 0, 0.97) 0%, rgba(0, 0, 0, 0.7) 8%, rgba(0, 0, 0, 0) 18%),
			linear-gradient(0deg, rgba(0, 73, 124, 0.95) 0%, rgba(0, 73, 124, 0.58) 12%, rgba(0, 73, 124, 0) 24%);
	}

	body.mgk-at-page-bottom .wp-site-blocks::after {
		opacity: 1;
		background:
			linear-gradient(180deg, rgba(0, 0, 0, 0.97) 0%, rgba(0, 0, 0, 0.7) 8%, rgba(0, 0, 0, 0) 18%);
	}

	body.home {
		height: auto;
		overflow-y: auto;
	}

	body.home .wp-site-blocks {
		height: auto;
		min-height: 100vh;
		overflow: visible;
	}

	body.home .mgk-hero {
		height: auto;
		min-height: 100vh;
	}

	.mgk-site-chrome--bottom-left {
		left: 50%;
		top: 38px;
		bottom: auto;
		width: clamp(110px, 21.6vw, 158px);
		transform: translateX(-50%) rotate(90deg);
		transform-origin: center;
	}

	.mgk-site-chrome--bottom-right {
		left: 50%;
		right: auto;
		bottom: 24px;
		top: auto;
		flex-direction: row;
		width: auto;
		gap: 15px;
		transform: translateX(-50%);
	}

	.mgk-hero {
		height: auto;
		min-height: 100vh;
		padding-top: 110px;
		padding-bottom: 80px;
	}

	.mgk-hero__grid {
		grid-template-columns: 1fr;
		height: auto;
	}

	.mgk-hero__copy {
		max-width: 100%;
		order: 2;
		text-align: center;
		justify-self: center;
	}

	.mgk-hero__art {
		order: 1;
		height: auto;
		min-height: 420px;
		margin-top: -18px;
	}

	.mgk-hero__orbit-icons {
		width: min(86vw, 620px);
		height: min(86vw, 620px);
	}

	.mgk-hero__orbit-item {
		width: 28px;
		height: 28px;
		transform:
			translate(-50%, -50%)
			rotate(var(--angle))
			translateY(calc(-1 * min(34vw, 240px)))
			rotate(calc(-1 * var(--angle)));
	}

	.mgk-hero__ring--large {
		width: min(72vw, 500px);
		height: min(72vw, 500px);
	}

	.mgk-hero__ring--small {
		width: min(52vw, 300px);
		height: min(52vw, 300px);
	}

	.mgk-hero__buttons {
		justify-content: center;
	}

	.mgk-hero__buttons .wp-block-button__link {
		padding: 0.68rem 1.45rem;
		font-size: 0.85rem;
	}
}

.mgk-template-main--portfolio {
	padding:
		0
		clamp(24px, 4vw, 48px)
		clamp(20px, 3vh, 38px);
	margin-block-start: 0;
}

.mgk-portfolio-showcase {
	width: min(100%, 1310px);
	margin: 0 auto;
	position: relative;
}

.mgk-portfolio-showcase__header {
	position: relative;
	min-height: clamp(160px, 24vw, 160px);
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 24px;
	padding: clamp(24px, 3vw, 34px);
	padding-right: clamp(24px, 4vw, 48px);
	background-color: #000;
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
	border: 1px solid #0b4f7c;
	border-top: 0;
	border-radius: 0 0 18px 18px;
	overflow: hidden;
}

.mgk-portfolio-showcase__eyebrow {
	position: absolute;
	z-index: 1;
	top: 16px;
	left: clamp(24px, 3vw, 34px);
	margin: 0;
	color: #58bceb;
	font-size: 0.78rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.mgk-portfolio-showcase__header-overlay {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(0, 0, 0, 0.08) 0%, rgba(0, 0, 0, 0.42) 52%, rgba(0, 0, 0, 0.8) 100%),
		linear-gradient(90deg, rgba(0, 0, 0, 0.46) 0%, rgba(0, 0, 0, 0.12) 40%, rgba(0, 0, 0, 0.22) 100%);
	pointer-events: none;
}

.mgk-portfolio-showcase__title {
	position: relative;
	z-index: 1;
	margin: 0;
	font-size: clamp(2.2rem, 4.4vw, 3.2rem);
	line-height: 1.02;
	letter-spacing: 0.02em;
	text-align: left;
}

.mgk-portfolio-showcase__nav {
	position: relative;
	z-index: 1;
	display: flex;
	gap: 14px;
	flex: 0 0 auto;
	margin-left: auto;
	align-self: flex-end;
}

.mgk-portfolio-showcase__arrow {
	width: 56px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	border: 1px solid #58bceb;
	border-radius: 999px;
	background: rgba(2, 23, 40, 0.35);
	box-shadow: none;
	color: #fff;
	font-size: 1.25rem;
	line-height: 1;
	cursor: pointer;
	transition: color 0.6s ease, background-color 0.6s ease, border-color 0.6s ease, box-shadow 0.6s ease;
}

.mgk-portfolio-showcase__arrow:hover,
.mgk-portfolio-showcase__arrow:focus-visible {
	color: white;
	background-color: #359dff75;
	border: 1px solid #60b0ff;
	box-shadow: 0 0 5px #256692, 0 0 7px #256692, 0 0 7px #256692;
}

.mgk-portfolio-showcase__viewport {
	position: relative;
	overflow-x: hidden;
	overflow-y: visible;
	padding-top: clamp(36px, 3.4vw, 56px);
	padding-left: clamp(8px, 1.2vw, 18px);
	padding-right: clamp(18px, 2.6vw, 44px);
	padding-bottom: clamp(4px, 1.4vw, 16px);
	box-sizing: border-box;
}

.mgk-portfolio-showcase__track {
	display: flex;
	transition: transform 0.72s cubic-bezier(0.22, 0.8, 0.24, 1);
	will-change: transform;
}

.mgk-portfolio-slide {
	display: grid;
	grid-template-columns: minmax(360px, 0.9fr) minmax(0, 1.1fr);
	align-items: start;
	gap: clamp(28px, 3.4vw, 52px);
	flex: 0 0 100%;
	width: 100%;
	min-width: 100%;
	box-sizing: border-box;
	padding: 4px clamp(12px, 1.8vw, 30px) clamp(8px, 1.6vw, 18px);
	overflow: visible;
	opacity: 0.28;
	transform: scale(0.985);
	visibility: hidden;
	transition:
		opacity 0.42s ease,
		transform 0.42s ease,
		visibility 0s linear 0.42s;
}

.mgk-portfolio-slide.is-active {
	opacity: 1;
	transform: scale(1);
	visibility: visible;
	transition-delay: 0s;
}

.mgk-portfolio-slide__copy {
	max-width: 660px;
}

.mgk-portfolio-slide__logo {
	width: min(300px, 72%);
	margin-bottom: clamp(22px, 3vw, 34px);
}

.mgk-portfolio-slide__logo img {
	display: block;
	max-width: 150px;
	max-height: 45px;
	height: auto;
	object-fit: contain;
	filter: brightness(0) invert(1) drop-shadow(0 0 12px rgba(88, 188, 235, 0.24));
	opacity: 0.9;
}

.mgk-portfolio-slide__content {
	color: var(--wp--preset--color--space-muted);
	font-size: 0.86rem;
	letter-spacing: 0.03em;
	line-height: 1.78;
}

.mgk-portfolio-slide__content > *:first-child {
	margin-top: 0;
}

.mgk-portfolio-slide__content > *:last-child {
	margin-bottom: 0;
}

.mgk-portfolio-slide__tech {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: clamp(24px, 3vw, 34px);
}

.mgk-portfolio-slide__tech-item {
	position: relative;
	width: 52px;
	height: 42px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(115, 169, 209, 0.24);
	border-radius: 10px;
	background: rgba(1, 12, 24, 0.64);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.04),
		0 0 18px rgba(88, 188, 235, 0.08);
	color: #fff;
	font-size: 0.76rem;
	text-transform: uppercase;
	cursor: help;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.mgk-portfolio-slide__tech-item img {
	display: block;
	width: 24px;
	height: 24px;
	object-fit: contain;
}

.mgk-portfolio-slide__tech-label {
	position: absolute;
	left: 50%;
	bottom: calc(100% + 9px);
	z-index: 4;
	width: max-content;
	max-width: min(240px, 70vw);
	padding: 7px 10px;
	border: 1px solid rgba(115, 169, 209, 0.34);
	border-radius: 6px;
	background: rgba(1, 12, 24, 0.96);
	box-shadow: 0 0 16px rgba(88, 188, 235, 0.16);
	color: var(--wp--preset--color--space-text);
	font-size: 0.66rem;
	line-height: 1.35;
	text-align: center;
	text-transform: none;
	white-space: normal;
	opacity: 0;
	pointer-events: none;
	transform: translate(-50%, 5px);
	transition: opacity 0.18s ease, transform 0.18s ease;
}

.mgk-portfolio-slide__tech-item:hover,
.mgk-portfolio-slide__tech-item:focus-visible {
	border-color: rgba(115, 169, 209, 0.62);
	box-shadow: 0 0 18px rgba(88, 188, 235, 0.18);
	outline: none;
}

.mgk-portfolio-slide__tech-item:hover .mgk-portfolio-slide__tech-label,
.mgk-portfolio-slide__tech-item:focus-visible .mgk-portfolio-slide__tech-label {
	opacity: 1;
	transform: translate(-50%, 0);
}

.mgk-portfolio-slide__tech-item:first-child .mgk-portfolio-slide__tech-label {
	left: 0;
	transform: translate(0, 5px);
}

.mgk-portfolio-slide__tech-item:first-child:hover .mgk-portfolio-slide__tech-label,
.mgk-portfolio-slide__tech-item:first-child:focus-visible .mgk-portfolio-slide__tech-label {
	transform: translate(0, 0);
}

.mgk-portfolio-slide__tech-item:last-child .mgk-portfolio-slide__tech-label {
	right: 0;
	left: auto;
	transform: translate(0, 5px);
}

.mgk-portfolio-slide__tech-item:last-child:hover .mgk-portfolio-slide__tech-label,
.mgk-portfolio-slide__tech-item:last-child:focus-visible .mgk-portfolio-slide__tech-label {
	transform: translate(0, 0);
}

.mgk-portfolio-slide__buttons {
	margin-top: 34px;
	display: flex;
	justify-content: flex-start;
}

.mgk-portfolio-slide__visual {
	position: relative;
	min-height: clamp(400px, 43vw, 640px);
	display: flex;
	align-items: flex-start;
	justify-content: flex-end;
	min-width: 0;
	padding: clamp(16px, 2vw, 30px) clamp(22px, 2.2vw, 40px) 28px clamp(28px, 3vw, 52px);
	box-sizing: border-box;
}

.mgk-portfolio-device-stack {
	position: relative;
	width: min(100%, 828px);
}

.mgk-portfolio-device-stack::before {
	content: "";
	position: absolute;
	inset: 10% -1% -13% 10%;
	background:
		radial-gradient(ellipse at center, rgba(88, 188, 235, 0.34), transparent 62%),
		radial-gradient(ellipse at 22% 72%, rgba(255, 42, 42, 0.14), transparent 42%);
	filter: blur(20px);
	pointer-events: none;
}

.mgk-portfolio-device-stack::after {
	content: "";
	position: absolute;
	inset: -16px -10px -20px;
	background:
		linear-gradient(90deg, transparent 0 18%, rgba(88, 188, 235, 0.1) 19%, transparent 20% 100%),
		linear-gradient(180deg, transparent 0 55%, rgba(88, 188, 235, 0.08) 56%, transparent 57% 100%);
	opacity: 0.55;
	mask-image: radial-gradient(ellipse at 58% 48%, #000 0 54%, transparent 76%);
	pointer-events: none;
}

.mgk-portfolio-device {
	position: relative;
	background:
		linear-gradient(135deg, rgba(198, 235, 255, 0.18), rgba(88, 188, 235, 0.04) 35%, rgba(255, 42, 42, 0.09) 100%),
		linear-gradient(180deg, #06111d 0%, #01060c 100%);
	border: 1px solid rgba(133, 207, 255, 0.34);
	box-shadow:
		0 0 24px rgba(88, 188, 235, 0.22),
		0 0 48px rgba(88, 188, 235, 0.14),
		0 0 24px rgba(255, 42, 42, 0.08),
		inset 0 0 0 1px rgba(255, 255, 255, 0.08),
		inset 0 0 0 4px #02070d,
		inset 0 0 24px rgba(88, 188, 235, 0.07);
	isolation: isolate;
}

.mgk-portfolio-device::before {
	content: "";
	position: absolute;
	inset: -2px;
	border-radius: inherit;
	background:
		linear-gradient(120deg, rgba(88, 188, 235, 0.9), transparent 22%, transparent 74%, rgba(255, 42, 42, 0.45));
	opacity: 0.52;
	z-index: -1;
	filter: blur(5px);
	pointer-events: none;
}

.mgk-portfolio-device::after {
	content: "";
	position: absolute;
	inset: 6px;
	border-radius: inherit;
	background:
		linear-gradient(110deg, rgba(255, 255, 255, 0.18), transparent 18% 100%),
		linear-gradient(180deg, rgba(88, 188, 235, 0.08), transparent 34% 100%);
	mix-blend-mode: screen;
	opacity: 0.55;
	pointer-events: none;
	z-index: 3;
}

.mgk-portfolio-device--desktop {
	width: 100%;
	aspect-ratio: 16 / 10;
	padding: 10px;
	border-radius: 24px;
}

.mgk-portfolio-device__screen {
	position: relative;
	width: 100%;
	height: 100%;
	overflow: hidden;
	background:
		linear-gradient(135deg, rgba(88, 188, 235, 0.1), transparent 40%),
		#eef7ff;
	box-shadow:
		inset 0 0 0 1px rgba(255, 255, 255, 0.18),
		inset 0 0 34px rgba(0, 0, 0, 0.12);
	z-index: 1;
}

.mgk-portfolio-device__screen::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(115deg, rgba(255, 255, 255, 0.22), transparent 24% 100%),
		repeating-linear-gradient(180deg, rgba(255, 255, 255, 0.04) 0 1px, transparent 1px 4px);
	opacity: 0.28;
	mix-blend-mode: screen;
	pointer-events: none;
	z-index: 2;
}

.mgk-portfolio-device__screen::after {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 18% 12%, rgba(88, 188, 235, 0.18), transparent 26%),
		linear-gradient(180deg, transparent 72%, rgba(3, 25, 42, 0.3) 100%);
	pointer-events: none;
	z-index: 2;
}

.mgk-portfolio-device--desktop .mgk-portfolio-device__screen {
	border-radius: 14px;
}

.mgk-portfolio-device__screen img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top center;
}

.mgk-portfolio-device--mobile {
	position: absolute;
	left: 8%;
	bottom: -19%;
	width: clamp(96px, 12vw, 142px);
	aspect-ratio: 9 / 18;
	padding: 6px;
	border-radius: 22px;
	box-shadow:
		0 0 22px rgba(88, 188, 235, 0.24),
		0 0 48px rgba(88, 188, 235, 0.18),
		0 0 26px rgba(255, 42, 42, 0.1),
		inset 0 0 0 4px #02070d,
		inset 0 0 26px rgba(88, 188, 235, 0.08);
}

.mgk-portfolio-device--mobile .mgk-portfolio-device__screen {
	border-radius: 16px;
}

.mgk-portfolio-device > p,
.mgk-portfolio-device-stack > p,
.mgk-portfolio-slide__visual > p {
	display: none;
	margin: 0;
}

.mgk-portfolio-showcase__empty {
	position: relative;
	z-index: 2;
	color: rgba(234, 246, 255, 0.78);
}

@media (max-width: 1024px) and (orientation: portrait) {
	.mgk-overlay-nav {
		background-color: rgba(0, 0, 0, 0.94);
	}

	.mgk-overlay-nav__panel {
		width: 100%;
		border-left: 0;
		box-shadow: none;
		padding: 110px 12% 64px;
	}

	.mgk-overlay-nav .wp-block-navigation-item {
		margin: 0 0 24px;
	}

	.mgk-portfolio-slide {
		grid-template-columns: 1fr;
	}

	.mgk-portfolio-slide__visual {
		order: -1;
		min-height: clamp(310px, 58vw, 520px);
		padding-inline: clamp(24px, 6vw, 46px);
	}

	.mgk-portfolio-slide__copy {
		max-width: 760px;
	}
}

@media (max-width: 980px) {
	.mgk-portfolio-slide {
		grid-template-columns: 1fr;
	}

	.mgk-portfolio-slide__visual {
		order: -1;
		min-height: clamp(310px, 58vw, 520px);
		padding-inline: clamp(24px, 6vw, 46px);
	}

	.mgk-portfolio-slide__copy {
		max-width: 760px;
	}
}

@media (max-width: 640px) {
	.mgk-overlay-nav {
		background-color: rgba(0, 0, 0, 0.94);
	}

	.mgk-overlay-nav__panel {
		width: 100%;
		border-left: 0;
		box-shadow: none;
		padding: 96px 32px 48px 44px;
	}

	.mgk-overlay-nav__meta {
		justify-content: flex-start;
		max-width: 240px;
	}

	.mgk-template-main--404 {
		padding-top: 124px;
	}

	.mgk-template-main--page {
		padding:
			0
			32px
			96px;
	}

	.mgk-page-header {
		min-height: 190px;
		border-radius: 0 0 12px 12px;
	}

	.mgk-page-header__inner {
		padding: 18px 20px;
	}

	.mgk-page-header__title {
		font-size: clamp(1.9rem, 8vw, 2.8rem);
	}

	.mgk-404__helmet {
		width: 126px;
		margin-bottom: 28px;
	}

	.mgk-404__lead {
		letter-spacing: 0.08em;
	}

	.mgk-menu-toggle {
		width: 32px;
	}

	.mgk-site-chrome--top-left,
	.mgk-site-chrome--top-right,
	.mgk-site-chrome--bottom-right {
		top: auto;
		right: auto;
		left: auto;
		bottom: auto;
	}

	.mgk-site-chrome--top-left {
		top: 18px;
		left: 19px;
	}

	.mgk-site-chrome--top-right {
        top: 28px;
        right: 19px;
	}

	.mgk-site-chrome--bottom-left {
		left: 50%;
        top: 15px;
        bottom: auto;
        width: 140px;
		transform: translateX(-50%) rotate(90deg);
	}

	.mgk-site-chrome--bottom-right {
		left: 50%;
		right: auto;
		bottom: 18px;
		flex-direction: row;
		width: auto;
		transform: translateX(-50%);
	}

	.mgk-hero {
		padding-top: 92px;
		padding-bottom: 96px;
		height: auto;
	}

	.mgk-hero__copy .wp-block-heading,
	.mgk-hero__copy p {
		text-align: center;
	}

	.mgk-hero__copy p {
		font-size: 0.92rem;
		line-height: 1.6;
	}

	.mgk-hero__copy p.has-medium-font-size {
		font-size: 0.92rem !important;
		line-height: 1.6;
	}

	.mgk-hero__typewriter-description {
		min-height: 7em;
	}

	.mgk-hero__art {
		min-height: 340px;
		margin-top: -10px;
	}

	.mgk-hero__orbit-icons {
		display: block;
		width: min(92vw, 420px);
		height: min(92vw, 420px);
	}

	.mgk-hero__orbit-item {
		width: 22px;
		height: 22px;
		transform:
			translate(-50%, -50%)
			rotate(var(--angle))
			translateY(calc(-1 * min(39vw, 175px)))
			rotate(calc(-1 * var(--angle)));
	}

	.mgk-hero__ring--large {
		display: block;
		width: min(92vw, 380px);
		height: min(92vw, 380px);
	}

	.mgk-hero__ring--small {
		width: min(70vw, 265px);
		height: min(70vw, 265px);
	}

	.mgk-hero__astronaut {
		max-width: min(100%, 340px);
	}

	.mgk-hero__buttons .wp-block-button__link {
		padding: 0.62rem 1.2rem;
		font-size: 0.78rem;
	}

	.mgk-template-main--portfolio {
		padding:
			0
			16px
			32px;
	}

	.mgk-portfolio-showcase__eyebrow {
		top: 14px;
		left: 20px;
		font-size: 0.68rem;
	}

	.mgk-portfolio-showcase__header {
		align-items: stretch;
		flex-direction: column;
		justify-content: flex-end;
		margin-bottom: 26px;
		min-height: 210px;
		padding: 18px 20px;
		gap: 12px;
	}

	.mgk-portfolio-showcase__title {
		font-size: clamp(1.9rem, 8vw, 2.8rem);
	}

	.mgk-portfolio-showcase__nav {
		order: -1;
		align-self: flex-end;
		margin: 0;
	}

	.mgk-portfolio-showcase__arrow {
		width: 44px;
		height: 38px;
		border-radius: 999px;
	}

	.mgk-portfolio-slide {
		gap: 26px;
	}

	.mgk-portfolio-slide__visual {
		min-height: 280px;
		padding: 0 14px 34px 22px;
	}

	.mgk-portfolio-device--desktop {
		padding: 7px;
		border-radius: 18px;
		box-shadow:
			0 0 22px rgba(88, 188, 235, 0.22),
			0 0 44px rgba(88, 188, 235, 0.16),
			0 0 22px rgba(255, 42, 42, 0.08),
			inset 0 0 0 3px #02070d,
			inset 0 0 18px rgba(88, 188, 235, 0.08);
	}

	.mgk-portfolio-device--desktop .mgk-portfolio-device__screen {
		border-radius: 11px;
	}

	.mgk-portfolio-device--mobile {
		left: 8%;
		bottom: -16%;
		width: clamp(70px, 20vw, 96px);
		padding: 4px;
		border-radius: 16px;
		box-shadow:
			0 0 18px rgba(88, 188, 235, 0.22),
			0 0 36px rgba(88, 188, 235, 0.16),
			0 0 18px rgba(255, 42, 42, 0.08),
			inset 0 0 0 3px #02070d,
			inset 0 0 18px rgba(88, 188, 235, 0.07);
	}

	.mgk-portfolio-device--mobile .mgk-portfolio-device__screen {
		border-radius: 12px;
	}

	.mgk-portfolio-slide__logo {
		width: min(240px, 78%);
	}

	.mgk-portfolio-slide__content {
		font-size: 0.89rem;
		line-height: 1.68;
	}

	.mgk-portfolio-slide__tech-item {
		width: auto;
		max-width: 100%;
		height: 38px;
		gap: 8px;
		padding: 0 10px;
		cursor: default;
		text-transform: none;
	}

	.mgk-portfolio-slide__tech-label {
		position: static;
		width: auto;
		max-width: none;
		padding: 0;
		border: 0;
		background: transparent;
		box-shadow: none;
		color: var(--wp--preset--color--space-muted);
		font-size: 0.65rem;
		line-height: 1.25;
		text-align: left;
		opacity: 1;
		transform: none;
	}

	.mgk-portfolio-slide__tech-item:hover .mgk-portfolio-slide__tech-label,
	.mgk-portfolio-slide__tech-item:focus-visible .mgk-portfolio-slide__tech-label,
	.mgk-portfolio-slide__tech-item:first-child .mgk-portfolio-slide__tech-label,
	.mgk-portfolio-slide__tech-item:first-child:hover .mgk-portfolio-slide__tech-label,
	.mgk-portfolio-slide__tech-item:first-child:focus-visible .mgk-portfolio-slide__tech-label,
	.mgk-portfolio-slide__tech-item:last-child .mgk-portfolio-slide__tech-label,
	.mgk-portfolio-slide__tech-item:last-child:hover .mgk-portfolio-slide__tech-label,
	.mgk-portfolio-slide__tech-item:last-child:focus-visible .mgk-portfolio-slide__tech-label {
		transform: none;
	}

	.mgk-portfolio-slide__buttons {
		justify-content: center;
		margin-top: 26px;
		padding-inline: 12px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.mgk-portfolio-showcase__track,
	.mgk-portfolio-slide {
		transition: none;
	}
}
