/*
Theme Name: SmartBis Dubai
Theme URI: https://smartbis.ae
Author: SmartBis
Author URI: https://smartbis.ae
Description: Лёгкая тема для сайта SmartBis — цифровые решения для бизнеса в Дубае.
Version: 1.0.0
Text Domain: smartbis-dubai
*/

/* Base reset */
*,
*::before,
*::after {
	box-sizing: border-box;
}
html {
	scroll-behavior: smooth;
}
body {
	margin: 0;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Inter, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", sans-serif;
	color: #fefbff;
	background: radial-gradient(circle at top, #1937b8 0, #050923 40%, #00020b 100%);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
body::before {
	content: "";
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: -1;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.04) 1px, transparent 1px);
	background-size: 80px 80px;
	opacity: 0.4;
	mix-blend-mode: soft-light;
}
img {
	max-width: 100%;
	height: auto;
	display: block;
}
a {
	color: #4b6bff;
	text-decoration: none;
}
a:hover {
	text-decoration: underline;
}
/* Layout */
.container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
}

/* Prevent accidental horizontal page scroll on mobile/desktop */
html, body {
	max-width: 100%;
	overflow-x: hidden;
}
.section {
	padding: 72px 0;
}
.section--muted {
	background: radial-gradient(circle at top, rgba(34, 74, 197, 0.9), rgba(5, 10, 32, 1));
}

/* CMS marquee */
.section--cms {
	background: radial-gradient(circle at top, rgba(18, 46, 160, 0.75), rgba(2, 4, 18, 1));
}
.cms-marquee {
	position: relative;
	overflow: hidden;
	padding: 10px 0 2px;
}
.cms-marquee::before,
.cms-marquee::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	width: 120px;
	z-index: 2;
	pointer-events: none;
}
.cms-marquee::before {
	left: 0;
	background: linear-gradient(90deg, rgba(2, 4, 18, 1), rgba(2, 4, 18, 0));
}
.cms-marquee::after {
	right: 0;
	background: linear-gradient(270deg, rgba(2, 4, 18, 1), rgba(2, 4, 18, 0));
}
.cms-marquee__track {
	display: flex;
	gap: 18px;
	width: max-content;
	will-change: transform;
	animation: cms-marquee var(--cms-speed, 28s) linear infinite;
}
.cms-marquee__group {
	display: flex;
	gap: 18px;
	padding: 0 18px;
}
.cms-logo {
	width: 160px;
	height: 76px;
	border-radius: 18px;
	display: flex;
	align-items: center;
	justify-content: center;
	background:
		radial-gradient(circle at 0 0, rgba(143, 176, 255, 0.18), transparent 55%),
		linear-gradient(145deg, rgba(4, 12, 40, 0.92), rgba(5, 18, 56, 0.92));
	border: 1px solid rgba(145, 175, 255, 0.45);
	box-shadow:
		0 16px 40px rgba(0, 0, 0, 0.75),
		0 0 0 1px rgba(36, 63, 140, 0.65);
}
.cms-logo__img {
	max-width: 80%;
	max-height: 78%;
	width: auto;
	height: auto;
	object-fit: contain;
	filter: none;
	opacity: 1;
	transition: opacity .2s ease-out, transform .2s ease-out;
}
.cms-logo:hover .cms-logo__img {
	opacity: 1;
	transform: translateY(-1px);
}
@keyframes cms-marquee {
	to { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
	.cms-marquee__track {
		animation: none;
	}
	.cms-marquee {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}
}
.grid {
	display: grid;
	gap: 24px;
}
.grid--2 {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}
.grid--3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 960px) {
	.grid--2,
	.grid--3 {
		grid-template-columns: 1fr;
	}
	.section {
		padding: 56px 0;
	}
}
/* Header – liquid glass */
.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	z-index: 50;
	padding: 22px 0 16px;
	background: linear-gradient(180deg, rgba(2, 6, 24, 0.55), rgba(2, 6, 24, 0));
	backdrop-filter: blur(10px) saturate(120%);
	transition: padding .22s ease-out, background .22s ease-out, backdrop-filter .22s ease-out;
}
.admin-bar .site-header {
	top: 32px;
}
@media screen and (max-width: 782px) {
	.admin-bar .site-header {
		top: 46px;
	}
}
.site-header--scrolled {
	padding: 12px 0 10px;
	/* remove the header strip behind the capsule */
	background: transparent;
	backdrop-filter: none;
}
.site-header__outer {
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.site-header__shell {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
	width: 100%;
	max-width: 100%;
	padding: 0;
	border-radius: 0;
	background: transparent;
	border: none;
	box-shadow: none;
	backdrop-filter: none;
	transition:
		padding .22s ease-out,
		border-radius .22s ease-out,
		background .22s ease-out,
		box-shadow .22s ease-out,
		max-width .22s ease-out;
}
.site-header--scrolled .site-header__shell {
	max-width: 960px;
	padding: 8px 22px;
	border-radius: 999px;
	background: radial-gradient(circle at top left, rgba(84, 125, 255, 0.32), transparent 55%) border-box,
		radial-gradient(circle at bottom right, rgba(80, 217, 255, 0.24), transparent 55%) border-box,
		linear-gradient(135deg, rgba(10, 10, 22, 0.9), rgba(12, 10, 30, 0.96)) padding-box;
	border: 1px solid rgba(255, 255, 255, 0.12);
	backdrop-filter: blur(20px) saturate(130%);
	box-shadow:
		0 10px 30px rgba(0, 0, 0, 0.9),
		0 0 0 1px rgba(108, 152, 255, 0.75);
	border-color: rgba(171, 194, 255, 0.7);
}
.site-content {
	padding-top: 96px;
}
body.home .site-content {
	padding-top: 0;
}
.site-header--scrolled .site-header__outer {
	justify-content: center;
}
.brand {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-weight: 700;
	font-size: 18px;
	color: #ffffff;
}
.brand__dot {
	width: 10px;
	height: 10px;
	background: #335cff;
	border-radius: 50%;
}
.brand__text {
	letter-spacing: .06em;
	text-transform: uppercase;
	font-size: 13px;
	opacity: .9;
}
.nav {
	flex: 1;
	display: flex;
	justify-content: center;
}
.nav .menu {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 28px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.nav .menu li {
	margin: 0;
	padding: 0;
}
.nav .menu a {
	color: #ffffff;
	font-weight: 500;
	font-size: 14px;
	text-decoration: none;
	padding: 4px 0;
	position: relative;
}
.nav .menu a::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -4px;
	height: 2px;
	border-radius: 999px;
	background: linear-gradient(90deg, rgba(143, 176, 255, 0.9), rgba(63, 191, 255, 0.9));
	transform: scaleX(0);
	transform-origin: center;
	transition: transform .16s ease-out, opacity .16s ease-out;
	opacity: 0;
}
.nav .menu a:hover::after,
.nav .menu .current-menu-item > a::after {
	transform: scaleX(1);
	opacity: 1;
}
.nav .menu a:hover {
	color: #ffffff;
}
.header-cta {
	display: flex;
	align-items: center;
	gap: 10px;
}
.nav-toggle {
	display: none;
	width: 34px;
	height: 34px;
	border-radius: 999px;
	border: 1px solid rgba(120, 150, 230, 0.9);
	background: radial-gradient(circle at 0 0, rgba(166, 187, 255, 0.18), transparent 55%),
		linear-gradient(135deg, rgba(5, 16, 60, 0.96), rgba(3, 11, 40, 0.96));
	box-shadow:
		0 10px 24px rgba(0, 0, 0, 0.9),
		0 0 0 1px rgba(21, 49, 126, 0.9);
	padding: 0;
	cursor: pointer;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 4px;
}
.nav-toggle span {
	display: block;
	width: 14px;
	height: 2px;
	border-radius: 999px;
	background: #dde6ff;
}
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 8px 18px;
	border-radius: 999px;
	font-size: 14px;
	font-weight: 600;
	border: 1px solid transparent;
	transition: all .18s ease-out;
	white-space: nowrap;
}
.header-cta__primary {
	padding-inline: 20px;
}
.header-cta__icons {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
.icon-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 999px;
	border: 1px solid rgba(120, 150, 230, 0.9);
	background: radial-gradient(circle at 0 0, rgba(166, 187, 255, 0.18), transparent 55%),
		linear-gradient(135deg, rgba(5, 16, 60, 0.96), rgba(3, 11, 40, 0.96));
	box-shadow:
		0 10px 24px rgba(0, 0, 0, 0.9),
		0 0 0 1px rgba(21, 49, 126, 0.9);
	transition: transform .16s ease-out, box-shadow .16s ease-out, border-color .16s ease-out;
	cursor: pointer;
	padding: 0;
	line-height: 0;
	background-clip: padding-box;
}
.icon-btn:hover {
	transform: translateY(-1px);
	box-shadow:
		0 14px 30px rgba(0, 0, 0, 0.96),
		0 0 0 1px rgba(40, 79, 173, 1);
	border-color: rgba(181, 203, 255, 1);
}
.lang-switcher {
	display: none;
	position: absolute;
	top: 100%;
	right: 0;
	margin-top: 6px;
	padding: 8px 10px;
	border-radius: 14px;
	background: rgba(5, 16, 60, 0.96);
	box-shadow:
		0 10px 24px rgba(0, 0, 0, 0.9),
		0 0 0 1px rgba(21, 49, 126, 0.9);
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: .08em;
	gap: 8px;
}
.header-cta__icons {
	position: relative;
}
.lang-switcher.is-open {
	display: inline-flex;
	align-items: stretch;
	flex-direction: column;
	min-width: 160px;
}
.lang-switcher a {
	display: flex;
	align-items: center;
	gap: 8px;
	color: rgba(199, 212, 255, 0.95);
	text-decoration: none;
	padding: 6px 8px;
	border-radius: 10px;
}
.lang-switcher a:hover {
	color: #ffffff;
	background: rgba(255, 255, 255, 0.08);
}
.lang-switcher img {
	width: 18px;
	height: 12px;
	border-radius: 3px;
	object-fit: cover;
}
.icon-svg {
	width: 16px;
	height: 16px;
	display: block;
	fill: none;
	stroke: #dde6ff;
	stroke-width: 1.7;
	stroke-linecap: round;
	stroke-linejoin: round;
}
.icon-btn--lang .icon-svg {
	stroke-width: 1.4;
}
.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}
.btn--primary {
	color: #05030b;
	background: radial-gradient(circle at top left, #c5d5ff, #7b9dff 40%, #335cff 100%);
	box-shadow:
		0 8px 22px rgba(0, 0, 0, 0.6),
		0 0 0 1px rgba(228, 236, 255, 0.9);
}
.btn--primary:hover {
	transform: translateY(-1px);
	box-shadow:
		0 12px 30px rgba(0, 0, 0, 0.8),
		0 0 0 1px rgba(255, 255, 255, 0.9);
}
@media (max-width: 768px) {
	.site-header {
		padding: 10px 0 8px;
	}
	.site-header__shell {
		gap: 10px;
		padding: 8px 14px;
	}
	.header-cta__icons {
		display: none;
	}
	.nav-toggle {
		display: inline-flex;
	}
	.nav {
		position: fixed;
		display: none;
	}
	html.nav-open {
		overflow: hidden;
	}

	/* Services tabs: keep inside viewport on mobile */
	.services-tabs {
		display: flex;
		width: 100%;
		max-width: 100%;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
	}
	.services-tabs::-webkit-scrollbar {
		display: none;
	}
	.services-tabs-wrap {
		position: relative;
		width: 100%;
		max-width: 100%;
	}
	/* leave space for arrows */
	.services-tabs {
		padding-left: 26px;
		padding-right: 26px;
	}
	.services-tabs__arrow {
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		width: 34px;
		height: 34px;
		border-radius: 999px;
		border: 1px solid rgba(120, 150, 230, 0.9);
		background: radial-gradient(circle at 0 0, rgba(166, 187, 255, 0.18), transparent 55%),
			linear-gradient(135deg, rgba(5, 16, 60, 0.96), rgba(3, 11, 40, 0.96));
		box-shadow:
			0 10px 22px rgba(0, 0, 0, 0.85),
			0 0 0 1px rgba(21, 49, 126, 0.9);
		color: rgba(235, 242, 255, 0.92);
		font-size: 18px;
		line-height: 1;
		display: none;
		align-items: center;
		justify-content: center;
		padding: 0;
		cursor: pointer;
		z-index: 2;
	}
	.services-tabs__arrow--left { left: -4px; }
	.services-tabs__arrow--right { right: -4px; }
	.services-tabs-wrap.is-scrollable .services-tabs__arrow { display: inline-flex; }
	.services-tabs-wrap.at-start .services-tabs__arrow--left { opacity: 0.25; }
	.services-tabs-wrap.at-end .services-tabs__arrow--right { opacity: 0.25; }
	.services-tabs__arrow:disabled {
		cursor: default;
	}
	.services-tab {
		flex: 0 0 auto;
		white-space: nowrap;
		padding: 6px 12px;
		font-size: 12px;
	}
}

/* Desktop (mouse): never show services tabs arrows, even if viewport is narrow (e.g., DevTools) */
@media (hover: hover) and (pointer: fine) {
	.services-tabs__arrow {
		display: none !important;
	}
	.services-tabs {
		padding-left: 4px;
		padding-right: 4px;
	}
}

/* Mobile nav overlay */
.mobile-nav {
	position: fixed;
	inset: 0;
	z-index: 150;
	display: none;
	align-items: center;
	justify-content: center;
	background: #000000;
}
.mobile-nav.is-open {
	display: flex;
}
.mobile-nav__inner {
	position: relative;
	width: 100%;
	height: 100%;
	max-width: 480px;
	margin: 0 auto;
	padding: 24px 28px;
	box-sizing: border-box;
	color: #ffffff;
}
.mobile-nav__close {
	position: absolute;
	top: 18px;
	right: 22px;
	width: 32px;
	height: 32px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.7);
	background: transparent;
	color: #ffffff;
	font-size: 22px;
	line-height: 1;
	cursor: pointer;
}
.mobile-nav__panel {
	display: none;
	margin-top: 40px;
}
.mobile-nav__panel.is-active {
	display: block;
}
.mobile-nav__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
}
.mobile-nav__link {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.25);
	background: transparent;
	border-radius: 0;
	color: #ffffff;
	font-size: 16px;
	text-align: left;
}
.mobile-nav__link--with-arrow .mobile-nav__arrow {
	font-size: 18px;
}
.mobile-nav__arrow {
	display: inline-block;
}
.mobile-nav__back {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-bottom: 18px;
	padding: 10px 0;
	border: 0;
	background: transparent;
	color: rgba(255, 255, 255, 0.8);
	font-size: 14px;
	cursor: pointer;
}
.mobile-nav__back-arrow {
	font-size: 18px;
}

@media (min-width: 769px) {
	.mobile-nav {
		display: none !important;
	}
}

/* Mega menu – Services */
.mega {
	position: fixed;
	left: 0;
	right: 0;
	top: 68px;
	z-index: 40;
	opacity: 0;
	pointer-events: none;
	transform: translateY(10px);
	transition: opacity .16s ease-out, transform .16s ease-out;
}
.mega.is-open {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}
.mega__inner {
	background: radial-gradient(circle at top, rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0.98));
	border-radius: 22px;
	padding: 22px 24px 20px;
	box-shadow:
		0 26px 70px rgba(0, 0, 0, 0.95),
		0 0 0 1px rgba(80, 83, 100, 0.7);
	color: #ffffff;
}
.mega-head {
	display: flex;
	gap: 32px;
	margin-bottom: 18px;
	font-size: 14px;
}
.mega-head__item {
	position: relative;
	padding-left: 16px;
	color: rgba(232, 233, 245, 0.7);
	border: none;
	background: transparent;
	cursor: pointer;
	font: inherit;
}
.mega-head__item::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	width: 6px;
	height: 6px;
	border-radius: 999px;
	background: #335cff;
	transform: translateY(-50%);
}
.mega-head__item.is-active {
	color: #ffffff;
}
.mega-body {
	position: relative;
	font-size: 13px;
}
.mega-panel {
	display: none;
	grid-template-columns: 1.4fr minmax(0, 3.6fr);
	gap: 32px;
}
.mega-panel.is-active {
	display: grid;
}
.mega-services {
	position: relative;
}
.mega-service {
	display: none;
	grid-template-columns: 1.4fr 1.4fr minmax(0, 1.2fr);
	gap: 32px;
}
.mega-service.is-active {
	display: grid;
}
.mega-col ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.mega-col--nav ul {
	border-right: 1px solid rgba(255, 255, 255, 0.08);
	padding-right: 18px;
}
.mega-col--nav li {
	padding: 6px 10px;
	border-radius: 12px;
	cursor: pointer;
}
.mega-col--nav li.is-active {
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.06));
}
.mega-col--note h3 {
	margin: 0 0 8px 0;
	font-size: 15px;
}
.mega-col--note p {
	margin: 0;
	font-size: 13px;
}

@media (max-width: 1024px) {
	.mega {
		display: none;
	}
}
/* Hero */
.hero {
	position: relative;
	padding: 140px 0 96px;
	overflow: hidden;
	background: transparent;
}

.hero--dg .hero__inner {
	display: grid;
	grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
	gap: 40px;
	align-items: center;
}
.hero__content {
	max-width: 640px;
}
.hero__actions {
	display: flex;
	gap: 12px;
	margin: 24px 0;
	flex-wrap: wrap;
}
.hero__meta {
	margin-top: 8px;
}
.hero-media-card {
	position: relative;
	min-width: 260px;
	max-width: 320px;
	border-radius: 32px;
	padding: 18px 20px 22px;
	background:
		radial-gradient(circle at 0 0, rgba(143, 176, 255, 0.35), transparent 55%),
		radial-gradient(circle at 100% 100%, rgba(63, 191, 255, 0.25), transparent 55%),
		linear-gradient(145deg, rgba(3, 10, 34, 0.98), rgba(5, 19, 59, 0.98));
	box-shadow:
		0 26px 60px rgba(0, 0, 0, 0.9),
		0 0 0 1px rgba(116, 155, 255, 0.4);
}
.hero-media-card__label {
	font-size: 12px;
	letter-spacing: .16em;
	text-transform: uppercase;
	opacity: .7;
	margin-bottom: 10px;
}
.hero-media-card__circle {
	width: 120px;
	height: 120px;
	border-radius: 999px;
	margin-bottom: 12px;
	background: radial-gradient(circle at 30% 0, #e9f0ff, #7b9dff 40%, #10225c 100%);
	box-shadow:
		0 18px 45px rgba(0, 0, 0, 0.85),
		0 0 0 1px rgba(231, 239, 255, 0.7);
}
.hero-media-card__text {
	font-size: 13px;
	color: rgba(224, 232, 255, 0.86);
}
.hero-media-card--video {
	padding: 0;
	overflow: hidden;
}
.hero-video {
	display: block;
	width: 100%;
	height: 220px;
	object-fit: cover;
}

.hero-video-bg {
	position: absolute;
	inset: 0;
	z-index: -1;
	overflow: hidden;
	pointer-events: none;
	background: #020618;
}
.hero-video-bg::after {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 20% 40%, rgba(0, 0, 0, 0.82), transparent 55%),
		linear-gradient(120deg, rgba(0, 2, 20, 0.85), rgba(0, 4, 24, 0.7), rgba(0, 8, 40, 0.2));
	mix-blend-mode: normal;
}
.hero-video-bg__video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Wrap for hero video + glow to avoid horizontal overflow */
.hero-shell {
	position: relative;
	overflow: hidden;
}

/* Mobile: show the whole 16:9 video (no crop) */
@media (max-width: 768px) {
	.hero-video-bg {
		display: flex;
		align-items: center;
		justify-content: center;
		background: #000000;
	}
	.hero-video-bg__video {
		width: 100%;
		height: 100%;
		object-fit: contain;
	}
}

.top-shell {
	position: relative;
	overflow: hidden;
}
.hero-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 6px 12px;
	border-radius: 999px;
	background: rgba(5, 15, 48, 0.9);
	border: 1px solid rgba(161, 188, 255, 0.5);
}
.hero-pill__dot {
	width: 6px;
	height: 6px;
	border-radius: 999px;
	background: #8fb0ff;
}
.hero-pill__text {
	font-size: 12px;
	color: rgba(224, 232, 255, 0.86);
}
.hero::before {
	content: "";
	position: absolute;
	inset: -20%;
	background:
		radial-gradient(circle at 20% 0, rgba(110, 144, 255, 0.26), transparent 55%),
		radial-gradient(circle at 80% 0, rgba(57, 102, 255, 0.26), transparent 55%),
		radial-gradient(circle at 50% 120%, rgba(63, 191, 255, 0.18), transparent 55%);
	opacity: 0.9;
	z-index: -1;
}
.hero::after {
	content: "";
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(circle at 10% 20%, rgba(255, 255, 255, 0.15) 0, transparent 45%),
		radial-gradient(circle at 80% 40%, rgba(255, 255, 255, 0.12) 0, transparent 50%),
		radial-gradient(circle at 30% 80%, rgba(255, 255, 255, 0.08) 0, transparent 45%);
	mix-blend-mode: screen;
	opacity: 0.45;
	z-index: -1;
}
.hero__eyebrow {
	display: inline-block;
	color: #8fb0ff;
	font-weight: 700;
	letter-spacing: .02em;
	margin-bottom: 16px;
}
.hero__title {
	font-size: clamp(28px, 5vw, 48px);
	font-weight: 800;
	line-height: 1.1;
	margin: 0 0 16px 0;
}
.hero__subtitle {
	font-size: clamp(16px, 2.5vw, 20px);
	color: rgba(237, 234, 255, 0.8);
	max-width: 920px;
	margin: 0 0 20px 0;
}
.divider {
	height: 1px;
	background: linear-gradient(90deg, rgba(99, 138, 255, 0.55), rgba(255, 255, 255, 0.06), rgba(63, 191, 255, 0.5));
	margin: 24px 0 0 0;
}
/* Cards & lists */
.card {
	background: radial-gradient(circle at top, rgba(255, 255, 255, 0.06), rgba(10, 9, 26, 0.96));
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 12px;
	padding: 20px;
}
.card h3 {
	margin: 0 0 8px 0;
	font-size: 18px;
}
.muted {
	color: rgba(216, 212, 246, 0.8);
}
.btn--ghost {
	color: #cfd9ff;
	background: rgba(7, 16, 48, 0.1);
	border-color: rgba(143, 176, 255, 0.5);
}
.btn--ghost:hover {
	background: rgba(7, 16, 48, 0.6);
}

.section-heading {
	margin-bottom: 32px;
	max-width: 780px;
}
.section-heading--center {
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}
.section-heading--between {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 24px;
}
.section-kicker {
	display: inline-block;
	font-size: 13px;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: rgba(181, 199, 255, 0.86);
	margin-bottom: 10px;
}
.section-title {
	font-size: clamp(24px, 3vw, 32px);
	margin: 0 0 8px 0;
}
.section-subtitle {
	margin: 0;
	color: rgba(199, 210, 255, 0.86);
	max-width: 640px;
}

.section--services {
	position: relative;
}
.services-tabs {
	display: inline-flex;
	gap: 10px;
	padding: 4px;
	border-radius: 999px;
	background: rgba(4, 11, 40, 0.95);
	border: 1px solid rgba(117, 148, 255, 0.5);
	margin-bottom: 28px;
}
.services-tab {
	border: 0;
	outline: 0;
	background: transparent;
	color: rgba(186, 203, 255, 0.8);
	font-size: 13px;
	font-weight: 500;
	padding: 6px 14px;
	border-radius: 999px;
	cursor: pointer;
}
.services-tab--active {
	background: linear-gradient(135deg, #7b9dff, #335cff);
	color: #05030b;
}
.services-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px;
}
.service-card {
	padding: 20px 22px;
	border-radius: 24px;
	background: radial-gradient(circle at 0 0, rgba(143, 176, 255, 0.25), transparent 55%),
		radial-gradient(circle at 100% 100%, rgba(63, 191, 255, 0.2), transparent 60%),
		linear-gradient(145deg, rgba(4, 12, 40, 0.98), rgba(5, 18, 56, 0.98));
	border: 1px solid rgba(145, 175, 255, 0.5);
	box-shadow:
		0 18px 45px rgba(0, 0, 0, 0.85),
		0 0 0 1px rgba(36, 63, 140, 0.8);
}
.service-card__label {
	font-size: 12px;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: rgba(181, 199, 255, 0.88);
	margin-bottom: 8px;
}
.service-card__title {
	margin: 0 0 8px 0;
	font-size: 18px;
}
.service-card__text {
	margin: 0 0 12px 0;
	color: rgba(209, 220, 255, 0.9);
}
.chip-list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0 0 12px 0;
	padding: 0;
	list-style: none;
}
.chip {
	padding: 5px 10px;
	border-radius: 999px;
	background: rgba(12, 28, 80, 0.9);
	border: 1px solid rgba(138, 166, 255, 0.7);
	font-size: 12px;
	color: rgba(219, 228, 255, 0.9);
}

.section--why {
	background: radial-gradient(circle at top, rgba(31, 63, 178, 0.5), rgba(3, 7, 30, 0.98));
}

.section--services-gallery {
	background: radial-gradient(circle at top, rgba(23, 52, 162, 0.8), rgba(1, 3, 18, 1));
}
.services-gallery {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 18px;
}
.services-gallery__item {
	border-radius: 18px;
	padding: 16px 18px;
	background:
		radial-gradient(circle at 0 0, rgba(143, 176, 255, 0.3), transparent 55%),
		linear-gradient(145deg, rgba(4, 12, 40, 0.98), rgba(5, 18, 56, 0.98));
	border: 1px solid rgba(145, 175, 255, 0.6);
	box-shadow:
		0 18px 45px rgba(0, 0, 0, 0.85),
		0 0 0 1px rgba(36, 63, 140, 0.8);
}
.services-gallery__title {
	margin: 0 0 6px 0;
	font-size: 16px;
}
.services-gallery__text {
	margin: 0;
	font-size: 13px;
}

.section--home-gallery {
	background: radial-gradient(circle at top, rgba(17, 40, 140, 0.85), rgba(2, 4, 18, 1));
}
.home-gallery {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 16px;
}
.home-gallery .wp-block-image img,
.home-gallery img {
	border-radius: 18px;
	box-shadow:
		0 18px 40px rgba(0, 0, 0, 0.9),
		0 0 0 1px rgba(36, 63, 140, 0.8);
}
.why-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px;
}
.why-card {
	padding: 20px 22px;
	border-radius: 24px;
	background: radial-gradient(circle at 0 0, rgba(143, 176, 255, 0.2), transparent 55%),
		linear-gradient(145deg, rgba(4, 11, 36, 0.98), rgba(5, 15, 49, 0.98));
	border: 1px solid rgba(126, 159, 255, 0.6);
}
.why-card__title {
	margin: 0 0 8px 0;
	font-size: 18px;
}

.section--founder {
	background: radial-gradient(circle at top, rgba(14, 42, 134, 0.7), rgba(3, 7, 30, 1));
}
.founder-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px;
}
.founder-card {
	padding: 20px 22px;
	border-radius: 24px;
	background: radial-gradient(circle at 0 0, rgba(143, 176, 255, 0.25), transparent 55%),
		linear-gradient(145deg, rgba(4, 11, 36, 0.98), rgba(5, 15, 49, 0.98));
	border: 1px solid rgba(126, 159, 255, 0.7);
}
.founder-card--profile {
	grid-row: span 2;
}
.founder-card--value {
	grid-column: span 2;
}
.founder-tag {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: 999px;
	background: rgba(8, 20, 70, 0.9);
	border: 1px solid rgba(162, 189, 255, 0.9);
	font-size: 12px;
	margin-bottom: 10px;
}
.founder-card__title {
	margin: 0 0 8px 0;
	font-size: 18px;
}

.section--positioning {
	background: radial-gradient(circle at top, rgba(23, 52, 162, 0.7), rgba(1, 3, 18, 1));
}
.positioning-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 20px;
}
.positioning-card {
	padding: 20px 22px;
	border-radius: 24px;
	background: radial-gradient(circle at 0 0, rgba(143, 176, 255, 0.25), transparent 55%),
		linear-gradient(145deg, rgba(3, 9, 35, 0.98), rgba(5, 16, 55, 0.98));
	border: 1px solid rgba(112, 145, 255, 0.7);
}
.positioning-card__title {
	margin: 0 0 8px 0;
	font-size: 18px;
}

.section--cases {
	background: radial-gradient(circle at top, rgba(13, 40, 132, 0.9), rgba(0, 4, 20, 1));
}
.cases-scroller {
	margin-top: 24px;
	overflow-x: auto;
	padding-bottom: 12px;
}
.cases-row {
	display: flex;
	gap: 18px;
	min-width: min(100%, 960px);
}
.case-card {
	min-width: 260px;
	max-width: 320px;
	flex: 0 0 auto;
	border-radius: 24px;
	overflow: hidden;
	background: radial-gradient(circle at 0 0, rgba(143, 176, 255, 0.25), transparent 55%),
		linear-gradient(145deg, rgba(3, 9, 35, 0.98), rgba(5, 16, 55, 0.98));
	border: 1px solid rgba(112, 145, 255, 0.7);
	box-shadow:
		0 20px 45px rgba(0, 0, 0, 0.9),
		0 0 0 1px rgba(36, 63, 140, 0.9);
}
.case-card__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	color: inherit;
	text-decoration: none;
}
.case-card__thumb {
	aspect-ratio: 16 / 9;
	background: rgba(2, 6, 24, 0.9);
	display: flex;
	align-items: center;
	justify-content: center;
}
.case-card__thumb img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.case-card__body {
	padding: 14px 16px 16px;
}
.case-card__title {
	margin: 0 0 6px 0;
	font-size: 16px;
}
.case-card__excerpt {
	font-size: 13px;
}
.case-card__work {
	margin: 8px 0 0 0;
	padding-left: 18px;
	font-size: 13px;
	color: rgba(199, 212, 255, 0.9);
}
.case-card__work li {
	margin: 4px 0;
}

/* Hosting page */
.section--hosting-hero {
	background: radial-gradient(circle at top, rgba(40, 88, 210, 0.9), rgba(3, 7, 30, 1));
}
.breadcrumbs {
	font-size: 12px;
	color: rgba(190, 205, 255, 0.8);
	margin-bottom: 12px;
}
.breadcrumbs a {
	color: rgba(190, 205, 255, 0.95);
	text-decoration: none;
}
.breadcrumbs a:hover {
	color: #ffffff;
}
.breadcrumbs__sep {
	margin: 0 6px;
	opacity: .7;
}
.hosting-hero-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
	gap: 32px;
	margin-top: 12px;
}
.hosting-hero-main p {
	margin: 0 0 14px 0;
	max-width: 640px;
	color: rgba(214, 225, 255, 0.9);
}
.hosting-hero-side {
	display: flex;
	justify-content: flex-end;
}
.hosting-highlight {
	max-width: 320px;
	padding: 18px 20px;
	border-radius: 22px;
	background:
		radial-gradient(circle at 0 0, rgba(143, 176, 255, 0.4), transparent 55%),
		linear-gradient(145deg, rgba(5, 16, 60, 0.98), rgba(3, 11, 40, 0.98));
	border: 1px solid rgba(145, 175, 255, 0.6);
	box-shadow:
		0 18px 45px rgba(0, 0, 0, 0.85),
		0 0 0 1px rgba(36, 63, 140, 0.8);
}
.hosting-highlight__title {
	margin: 0 0 8px 0;
	font-size: 18px;
}
.hosting-highlight__text {
	margin: 0;
	color: rgba(214, 225, 255, 0.9);
	font-size: 14px;
}

.section--hosting-feature {
	background: #050816;
}
.hosting-feature {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
	gap: 32px;
	align-items: center;
}
.hosting-feature__text .section-title {
	margin-bottom: 10px;
}
.hosting-feature-cards {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-top: 14px;
}
.hosting-feature-card {
	border-radius: 18px;
	background: rgba(3, 11, 40, 0.92);
	border: 1px solid rgba(63, 97, 205, 0.9);
	padding: 10px 14px;
	box-shadow: 0 14px 36px rgba(0, 0, 0, 0.75);
}
.hosting-feature-card__title {
	margin: 0 0 4px 0;
	font-size: 14px;
}
.hosting-feature-card__text {
	margin: 0;
	font-size: 13px;
	color: rgba(212, 223, 255, 0.9);
}
.hosting-feature__media {
	display: flex;
	justify-content: center;
}
.hosting-feature-media-card {
	border-radius: 18px;
	background: radial-gradient(circle at 0 0, rgba(143, 176, 255, 0.3), transparent 55%),
		linear-gradient(145deg, rgba(8, 20, 70, 0.98), rgba(5, 16, 60, 0.98));
	border: 1px solid rgba(145, 175, 255, 0.8);
	box-shadow:
		0 24px 60px rgba(0, 0, 0, 0.9),
		0 0 0 1px rgba(36, 63, 140, 0.9);
	padding: 10px;
	max-width: 640px;
}
.hosting-feature-media-card img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 12px;
}
.hosting-feature-media-card--placeholder {
	min-height: 260px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: left;
}

.section--hosting-uses {
	background: radial-gradient(circle at top, rgba(23, 52, 162, 0.7), rgba(1, 3, 18, 1));
}

.section--hosting-calculator {
	background: radial-gradient(circle at top, rgba(20, 52, 170, 0.85), rgba(2, 4, 18, 1));
}
.hosting-calc {
	display: grid;
	grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
	gap: 20px;
	align-items: start;
}
.hosting-calc__form,
.hosting-calc__result {
	border-radius: 20px;
	padding: 18px 18px;
	background:
		radial-gradient(circle at 0 0, rgba(143, 176, 255, 0.26), transparent 55%),
		linear-gradient(145deg, rgba(4, 12, 40, 0.98), rgba(5, 18, 56, 0.98));
	border: 1px solid rgba(145, 175, 255, 0.6);
	box-shadow:
		0 18px 45px rgba(0, 0, 0, 0.85),
		0 0 0 1px rgba(36, 63, 140, 0.8);
}
.hosting-calc__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}
.hosting-calc__field label {
	display: block;
	font-size: 12px;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: rgba(199, 212, 255, 0.9);
	margin: 0 0 6px 0;
}
.hosting-calc__field input,
.hosting-calc__field select {
	width: 100%;
	height: 42px;
	border-radius: 12px;
	border: 1px solid rgba(145, 175, 255, 0.45);
	background: rgba(255, 255, 255, 0.08);
	color: rgba(235, 242, 255, 0.95);
	padding: 0 12px;
	outline: none;
}
.hosting-calc__field input:focus,
.hosting-calc__field select:focus {
	border-color: rgba(181, 203, 255, 1);
	box-shadow: 0 0 0 3px rgba(51, 92, 255, 0.18);
}
.hosting-calc__toggles {
	grid-column: 1 / -1;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
	margin-top: 2px;
}
.hosting-calc__toggle {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 12px;
	border-radius: 14px;
	border: 1px solid rgba(145, 175, 255, 0.35);
	background: rgba(255, 255, 255, 0.06);
	cursor: pointer;
}
.hosting-calc__toggle input {
	width: 16px;
	height: 16px;
}
.hosting-calc__price-label {
	font-size: 12px;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: rgba(199, 212, 255, 0.9);
}
.hosting-calc__price-value {
	font-size: 34px;
	font-weight: 800;
	margin-top: 6px;
}
.hosting-calc__price-note {
	margin-top: 6px;
}
.hosting-calc__summary {
	margin-top: 12px;
	font-size: 13px;
	line-height: 1.5;
}
.hosting-calc__actions {
	margin-top: 14px;
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}
.hosting-uses-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px;
}
.hosting-card {
	padding: 20px 22px;
	border-radius: 20px;
	background:
		radial-gradient(circle at 0 0, rgba(143, 176, 255, 0.3), transparent 55%),
		linear-gradient(145deg, rgba(4, 12, 40, 0.98), rgba(5, 18, 56, 0.98));
	border: 1px solid rgba(145, 175, 255, 0.6);
	box-shadow:
		0 18px 45px rgba(0, 0, 0, 0.85),
		0 0 0 1px rgba(36, 63, 140, 0.8);
}
.hosting-card__title {
	margin: 0 0 8px 0;
	font-size: 18px;
}

.section--hosting-gallery {
	background: radial-gradient(circle at top, rgba(26, 60, 176, 0.8), rgba(2, 4, 18, 1));
}
.hosting-gallery__content {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 16px;
}
.hosting-gallery__content img {
	border-radius: 18px;
	width: 100%;
	height: 220px;
	object-fit: cover;
	box-shadow:
		0 16px 40px rgba(0, 0, 0, 0.9),
		0 0 0 1px rgba(36, 63, 140, 0.8);
}


@media (max-width: 960px) {
	.services-grid,
	.why-grid,
	.founder-grid,
	.positioning-grid,
	.hosting-uses-grid,
	.hosting-calc {
		grid-template-columns: 1fr;
	}
	.positioning-card,
	.founder-card--value {
		grid-column: auto;
	}
	.hero--dg .hero__inner {
		grid-template-columns: 1fr;
	}
	.hosting-feature {
		grid-template-columns: minmax(0, 1fr);
	}
	.hosting-feature__media {
		margin-top: 20px;
	}
	.container {
		padding: 0 16px;
	}
	.section {
		padding: 56px 0;
	}
	.hero {
		padding: 96px 0 72px;
	}
}
.list {
	margin: 12px 0 0 0;
	padding-left: 18px;
}
.list li {
	margin: 6px 0;
}
/* Footer */
.site-footer {
	border-top: 1px solid rgba(255, 255, 255, 0.06);
	background: radial-gradient(circle at top, rgba(11, 28, 90, 0.95), #020617);
	color: rgba(216, 222, 255, 0.8);
}
.footer-main {
	padding-top: 40px;
	padding-bottom: 28px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}
.footer-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
	margin-bottom: 28px;
}
.footer-logo {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-weight: 700;
	font-size: 20px;
}
.footer-logo__dot {
	width: 10px;
	height: 10px;
	border-radius: 999px;
	background: #335cff;
}
.footer-logo__text {
	letter-spacing: .08em;
	text-transform: uppercase;
	font-size: 13px;
}
.footer-cols {
	display: grid;
	grid-template-columns: 1.3fr repeat(3, minmax(0, 1fr));
	gap: 32px;
}
.footer-col__title {
	margin: 0 0 10px 0;
	font-size: 14px;
	text-transform: uppercase;
	letter-spacing: .14em;
	color: rgba(199, 212, 255, 0.9);
}
.footer-col__text {
	margin: 0 0 10px 0;
	font-size: 13px;
	color: rgba(183, 199, 255, 0.85);
}
.footer-links {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
	font-size: 13px;
}
.footer-links a {
	color: rgba(199, 212, 255, 0.9);
	text-decoration: none;
}
.footer-links a:hover {
	color: #ffffff;
}
.footer-bottom {
	padding: 16px 0 22px;
}
.footer-bottom__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	font-size: 12px;
	color: rgba(145, 164, 225, 0.9);
}
.footer-bottom__misc a {
	color: rgba(199, 212, 255, 0.9);
	text-decoration: none;
}
.footer-bottom__misc a:hover {
	color: #ffffff;
}

/* Modal contact form */
.modal-overlay {
	position: fixed;
	inset: 0;
	z-index: 200;
	display: none;
	align-items: center;
	justify-content: center;
	background: radial-gradient(circle at top, rgba(0,0,0,0.78), rgba(0,0,0,0.9));
	backdrop-filter: blur(14px);
	padding: 24px;
}
.modal-overlay.is-open {
	display: flex;
}
.modal {
	position: relative;
	max-width: 980px;
	width: 100%;
	border-radius: 26px;
	background:
		radial-gradient(circle at 0 0, rgba(143, 176, 255, 0.45), transparent 55%),
		radial-gradient(circle at 100% 100%, rgba(63, 191, 255, 0.35), transparent 60%),
		linear-gradient(145deg, rgba(8, 20, 70, 0.96), rgba(5, 16, 60, 0.96));
	box-shadow:
		0 24px 80px rgba(0,0,0,0.95),
		0 0 0 1px rgba(112, 145, 255, 0.85);
	color: rgba(230, 238, 255, 0.96);
}
.modal__close {
	position: absolute;
	top: 16px;
	right: 18px;
	width: 32px;
	height: 32px;
	border-radius: 999px;
	border: 1px solid rgba(20, 33, 80, 0.4);
	background: #ffffff;
	color: #111322;
	font-size: 20px;
	line-height: 1;
	cursor: pointer;
}
.modal__inner {
	padding: 32px 32px 26px;
}
.modal__title {
	margin: 6px 0 8px;
	font-size: 28px;
}
.modal__subtitle {
	margin: 0 0 18px;
	color: rgba(194, 208, 255, 0.9);
	max-width: 540px;
}
.modal-form {
	margin-top: 8px;
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.modal-form__row {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}
.modal-form__row--full {
	grid-template-columns: minmax(0, 1fr);
}
.modal-field {
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.modal-field label {
	font-size: 13px;
	color: rgba(175, 196, 255, 0.9);
}
.modal-field input,
.modal-field select,
.modal-field textarea {
	border-radius: 999px;
	border: 1px solid rgba(138, 166, 255, 0.7);
	padding: 10px 14px;
	font-size: 14px;
	font-family: inherit;
	outline: none;
	background: rgba(17, 32, 96, 0.94);
	color: rgba(236, 242, 255, 0.98);
}
.modal-field textarea {
	border-radius: 18px;
	resize: vertical;
}
.modal-form__footer {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-top: 4px;
}
.modal-form__status {
	font-size: 13px;
	color: #8be08b;
}
.modal-form__status.is-error {
	color: #ff8a80;
}
.modal-form__submit {
	padding-inline: 22px;
}

html.modal-open {
	overflow: hidden;
}

@media (max-width: 768px) {
.footer-main {
	padding-top: 28px;
	padding-bottom: 22px;
}

/* Tabs arrows: hidden by default (desktop), enabled via mobile rules */
.services-tabs__arrow {
	display: none;
}

.service-card.is-hidden {
	display: none;
}
.footer-head {
	flex-direction: column;
	align-items: flex-start;
}
.footer-cols {
	grid-template-columns: minmax(0, 1fr);
}
	.modal {
		max-width: 100%;
	}
	.modal__inner {
		padding: 24px 18px 20px;
	}
	.modal-form__row {
		grid-template-columns: minmax(0, 1fr);
	}
}


