.about-page {
	--about-line: rgba(70, 111, 205, 0.24);
	--about-line-bright: rgba(77, 110, 255, 0.48);
	--about-panel: linear-gradient(145deg, rgba(5, 12, 29, 0.95), rgba(2, 6, 16, 0.98));
	padding-top: calc(var(--header-height) + 36px);
	background:
		radial-gradient(circle at 72% 8%, rgba(52, 45, 194, 0.13), transparent 28rem),
		radial-gradient(circle at 10% 50%, rgba(21, 92, 214, 0.08), transparent 30rem);
}

.about-hero {
	padding-bottom: 42px;
}

.about-hero-panel {
	position: relative;
	display: grid;
	min-height: 645px;
	overflow: hidden;
	grid-template-columns: minmax(0, 0.98fr) minmax(420px, 1.02fr);
	grid-template-rows: 1fr auto;
	border: 1px solid var(--about-line);
	border-radius: 18px;
	background:
		linear-gradient(rgba(34, 74, 152, 0.032) 1px, transparent 1px),
		linear-gradient(90deg, rgba(34, 74, 152, 0.032) 1px, transparent 1px),
		radial-gradient(circle at 76% 34%, rgba(35, 63, 202, 0.14), transparent 25rem),
		var(--about-panel);
	background-size: 44px 44px, 44px 44px, auto, auto;
	box-shadow: 0 32px 90px rgba(0, 0, 0, 0.34);
}

.about-hero-panel::before,
.about-hero-panel::after {
	position: absolute;
	z-index: 0;
	border-radius: 50%;
	content: "";
	pointer-events: none;
}

.about-hero-panel::before {
	top: 80px;
	right: 92px;
	width: 440px;
	height: 440px;
	border: 1px solid rgba(76, 58, 255, 0.22);
	box-shadow: inset 0 0 70px rgba(34, 103, 255, 0.05), 0 0 90px rgba(99, 39, 255, 0.05);
}

.about-hero-panel::after {
	top: 126px;
	right: 136px;
	width: 350px;
	height: 350px;
	border: 1px dashed rgba(58, 107, 255, 0.14);
}

.about-hero-copy {
	position: relative;
	z-index: 2;
	align-self: center;
	padding: 64px 22px 88px 66px;
}

.about-kicker {
	display: inline-flex;
	min-height: 30px;
	align-items: center;
	gap: 9px;
	margin-bottom: 24px;
	padding: 5px 12px;
	border: 1px solid rgba(72, 108, 188, 0.24);
	border-radius: 999px;
	background: rgba(6, 13, 30, 0.76);
	color: #e8ebf5;
	font-size: 0.66rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.about-kicker span {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: linear-gradient(135deg, #286fff, #c42df1);
	box-shadow: 0 0 14px rgba(101, 63, 255, 0.75);
}

.about-hero h1 {
	max-width: 620px;
	margin-bottom: 25px;
	font-size: clamp(2.7rem, 4vw, 4.35rem);
	letter-spacing: -0.045em;
	line-height: 1.04;
}

.about-hero h1 span {
	display: block;
	max-width: 610px;
	margin-top: 11px;
	font-size: 0.68em;
	line-height: 1.12;
}

.about-hero-lead {
	max-width: 580px;
	margin-bottom: 31px;
	background: linear-gradient(90deg, #80a5ff, #a777ff);
	background-clip: text;
	color: transparent;
	font-size: clamp(1.03rem, 1.5vw, 1.24rem);
	font-weight: 600;
	line-height: 1.55;
}

.about-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
}

.about-actions .button {
	min-width: 178px;
}

.about-portrait {
	position: relative;
	z-index: 1;
	align-self: end;
	margin: 0;
	padding: 36px 32px 74px 0;
}

.about-portrait::before {
	position: absolute;
	z-index: -1;
	top: 16%;
	right: 4%;
	width: 88%;
	height: 76%;
	border-radius: 50%;
	background:
		radial-gradient(circle at 48% 48%, rgba(49, 129, 255, 0.31), rgba(118, 45, 255, 0.14) 43%, transparent 70%);
	content: "";
	filter: blur(25px);
	pointer-events: none;
}

.about-portrait-frame {
	position: relative;
	overflow: hidden;
	width: min(96%, 480px);
	aspect-ratio: 16 / 19;
	margin-left: auto;
	border-radius: 0 0 24px 24px;
	filter:
		drop-shadow(0 28px 34px rgba(0, 0, 0, 0.4))
		drop-shadow(0 0 23px rgba(65, 91, 255, 0.17));
}

.about-portrait-frame img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 0;
}

.about-stats {
	position: relative;
	z-index: 3;
	display: grid;
	min-height: 136px;
	grid-column: 1 / -1;
	grid-template-columns: repeat(4, 1fr);
	margin: -48px 46px 36px;
	border: 1px solid var(--about-line);
	border-radius: 15px;
	background: linear-gradient(145deg, rgba(5, 13, 31, 0.97), rgba(2, 7, 18, 0.99));
	box-shadow: 0 20px 55px rgba(0, 0, 0, 0.34);
}

.about-stat {
	position: relative;
	display: flex;
	min-width: 0;
	align-items: center;
	gap: 17px;
	padding: 23px 25px;
}

.about-stat:not(:last-child)::after {
	position: absolute;
	top: 24%;
	right: 0;
	width: 1px;
	height: 52%;
	background: var(--about-line);
	content: "";
}

.about-stat-icon {
	display: grid;
	width: 56px;
	height: 56px;
	flex: 0 0 56px;
	border: 1px solid transparent;
	border-radius: 50%;
	background: linear-gradient(#061027, #061027) padding-box, linear-gradient(135deg, #168dff, #a12cff) border-box;
	color: #586eff;
	place-items: center;
}

.about-stat-icon .icon {
	width: 29px;
	height: 29px;
}

.about-stat > div:last-child {
	display: flex;
	min-width: 0;
	flex-direction: column;
}

.about-stat strong {
	color: #fff;
	font-size: clamp(1.05rem, 1.7vw, 1.65rem);
	letter-spacing: -0.035em;
	line-height: 1.08;
}

.about-stat:nth-child(3) strong {
	font-size: clamp(0.9rem, 1.3vw, 1.2rem);
}

.about-stat span {
	margin-top: 7px;
	color: #aeb9ce;
	font-size: 0.68rem;
	font-weight: 600;
	line-height: 1.35;
}

.about-section {
	padding: 62px 0;
}

.about-section-heading {
	max-width: 690px;
	margin: 0 auto 34px;
	text-align: center;
}

.about-section-label {
	margin-bottom: 12px;
	color: #91a4d7;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
}

.about-section-heading h2,
.about-story-copy h2 {
	margin-bottom: 18px;
	font-size: clamp(2rem, 3vw, 3rem);
}

.about-section-heading > p:last-child {
	margin: 0;
	color: #aeb8ca;
	font-size: 0.88rem;
	line-height: 1.75;
}

.about-known-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 13px;
}

.about-known-card {
	position: relative;
	min-height: 320px;
	padding: 29px 25px 25px;
	border: 1px solid var(--about-line);
	border-radius: 14px;
	background: var(--about-panel);
	box-shadow: inset 0 1px rgba(255, 255, 255, 0.02);
	transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.about-known-card:hover {
	border-color: var(--about-line-bright);
	box-shadow: 0 18px 48px rgba(0, 0, 0, 0.3), 0 0 30px rgba(51, 68, 255, 0.07);
	transform: translateY(-5px);
}

.about-known-icon {
	display: grid;
	width: 58px;
	height: 58px;
	margin-bottom: 29px;
	border-radius: 14px;
	background: linear-gradient(145deg, rgba(15, 50, 106, 0.78), rgba(33, 13, 68, 0.75));
	color: #358cff;
	place-items: center;
}

.about-known-icon .icon {
	width: 33px;
	height: 33px;
}

.about-known-card h3 {
	margin-bottom: 18px;
	font-size: 1.05rem;
}

.about-known-card ul {
	display: grid;
	gap: 10px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.about-known-card li {
	display: flex;
	align-items: center;
	gap: 9px;
	color: #aeb8ca;
	font-size: 0.76rem;
}

.about-known-card li .icon {
	width: 14px;
	height: 14px;
	color: #568cff;
}

.about-story {
	padding-top: 72px;
}

.about-story-layout {
	display: grid;
	grid-template-columns: minmax(340px, 0.84fr) minmax(0, 1.16fr);
	align-items: start;
	gap: 72px;
}

.about-story-visual {
	position: sticky;
	top: calc(var(--header-height) + 35px);
}

.about-story-image {
	overflow: hidden;
	margin: 0;
	border: 1px solid transparent;
	border-radius: 16px;
	background: linear-gradient(#030817, #030817) padding-box, linear-gradient(135deg, #178cff, #9d26f0) border-box;
	box-shadow: 0 26px 70px rgba(0, 0, 0, 0.34);
}

.about-story-image img {
	width: 100%;
	aspect-ratio: 1.3;
	object-fit: cover;
}

.about-story-note {
	display: grid;
	grid-template-columns: 45px 1fr;
	align-items: center;
	gap: 14px;
	margin: 14px 14px 0;
	padding: 16px 18px;
	border: 1px solid var(--about-line);
	border-radius: 12px;
	background: var(--about-panel);
}

.about-story-note > .icon {
	width: 30px;
	height: 30px;
	color: #5589ff;
}

.about-story-note p {
	display: flex;
	flex-direction: column;
	margin: 0;
}

.about-story-note strong {
	color: #eef1f8;
	font-size: 0.75rem;
}

.about-story-note span {
	margin-top: 3px;
	color: #8490a8;
	font-size: 0.64rem;
	line-height: 1.5;
}

.about-story-copy > p:not(.about-section-label) {
	margin-bottom: 18px;
	color: #b2bbcc;
	font-size: 0.88rem;
	line-height: 1.84;
}

.about-story-copy .about-story-closing {
	margin-top: 26px;
	padding: 19px 22px;
	border-left: 2px solid #6e54ff;
	border-radius: 0 10px 10px 0;
	background: linear-gradient(90deg, rgba(38, 35, 100, 0.28), transparent);
	color: #f0f2f9;
	font-size: 0.95rem;
	font-weight: 650;
}

.about-industries {
	padding-top: 74px;
}

.about-industry-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 11px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.about-industry-grid li {
	display: flex;
	min-height: 88px;
	align-items: center;
	gap: 16px;
	padding: 17px 20px;
	border: 1px solid var(--about-line);
	border-radius: 12px;
	background: var(--about-panel);
	transition: border-color 180ms ease, transform 180ms ease;
}

.about-industry-grid li:hover {
	border-color: var(--about-line-bright);
	transform: translateY(-3px);
}

.about-industry-grid li > span {
	display: grid;
	width: 44px;
	height: 44px;
	flex: 0 0 44px;
	border-radius: 11px;
	background: linear-gradient(145deg, rgba(15, 50, 106, 0.72), rgba(33, 13, 68, 0.68));
	color: #558cff;
	place-items: center;
}

.about-industry-grid .icon {
	width: 23px;
	height: 23px;
}

.about-industry-grid strong {
	color: #e8ebf3;
	font-size: 0.82rem;
}

.about-contact-section {
	padding: 76px 0 78px;
}

.about-contact-card {
	display: grid;
	min-height: 142px;
	grid-template-columns: 72px 1fr auto;
	align-items: center;
	gap: 28px;
	padding: 27px 39px;
	border: 1px solid var(--about-line);
	border-radius: 16px;
	background: radial-gradient(circle at 10% 50%, rgba(35, 112, 255, 0.09), transparent 15rem), var(--about-panel);
}

.about-contact-icon {
	display: grid;
	width: 68px;
	height: 68px;
	border: 1px solid transparent;
	border-radius: 50%;
	background: linear-gradient(#071027, #071027) padding-box, linear-gradient(135deg, #168dff, #b12bff) border-box;
	color: #4a79ff;
	place-items: center;
}

.about-contact-icon .icon {
	width: 33px;
	height: 33px;
}

.about-contact-card h2 {
	margin-bottom: 7px;
	font-size: 1.62rem;
}

.about-contact-card h2 span {
	background: linear-gradient(90deg, #4c98ff, #9c51ff);
	background-clip: text;
	color: transparent;
}

.about-contact-card p {
	max-width: 660px;
	margin: 0;
	font-size: 0.82rem;
	line-height: 1.6;
}

.about-contact-card .button {
	min-width: 218px;
}

@media (max-width: 1120px) {
	.about-hero-panel {
		grid-template-columns: 1fr 0.9fr;
	}

	.about-hero-copy {
		padding-left: 42px;
	}

	.about-stats {
		margin-inline: 28px;
	}

	.about-stat {
		gap: 12px;
		padding-inline: 17px;
	}

	.about-stat-icon {
		width: 49px;
		height: 49px;
		flex-basis: 49px;
	}

	.about-known-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.about-known-card {
		min-height: 260px;
	}
}

@media (max-width: 900px) {
	.about-page {
		padding-top: calc(var(--header-height) + 24px);
	}

	.about-hero-panel {
		grid-template-columns: 1fr;
		grid-template-rows: auto auto auto;
	}

	.about-hero-panel::before {
		top: 455px;
		right: 50%;
		transform: translateX(50%);
	}

	.about-hero-panel::after {
		top: 500px;
		right: 50%;
		transform: translateX(50%);
	}

	.about-hero-copy {
		padding: 52px 50px 20px;
		text-align: center;
	}

	.about-kicker,
	.about-actions {
		justify-content: center;
	}

	.about-hero h1,
	.about-hero-lead {
		margin-right: auto;
		margin-left: auto;
	}

	.about-portrait {
		padding: 8px 28px 70px;
	}

	.about-portrait-frame {
		width: min(100%, 470px);
		margin-inline: auto;
	}

	.about-stats {
		grid-template-columns: repeat(2, 1fr);
		margin-top: -42px;
	}

	.about-stat:nth-child(2)::after {
		display: none;
	}

	.about-stat:nth-child(-n + 2) {
		border-bottom: 1px solid var(--about-line);
	}

	.about-story-layout {
		grid-template-columns: 0.85fr 1.15fr;
		gap: 35px;
	}

	.about-story-visual {
		position: static;
	}

	.about-contact-card {
		grid-template-columns: 65px 1fr;
	}

	.about-contact-card .button {
		width: 100%;
		grid-column: 1 / -1;
	}
}

@media (max-width: 680px) {
	.about-page {
		padding-top: calc(var(--header-height) + 15px);
	}

	.about-hero {
		padding-bottom: 25px;
	}

	.about-hero-panel {
		border-radius: 14px;
	}

	.about-hero-panel::before {
		top: 465px;
		width: 330px;
		height: 330px;
	}

	.about-hero-panel::after {
		top: 502px;
		width: 260px;
		height: 260px;
	}

	.about-hero-copy {
		padding: 36px 18px 10px;
		text-align: left;
	}

	.about-kicker {
		justify-content: flex-start;
		margin-bottom: 19px;
	}

	.about-hero h1 {
		margin-bottom: 20px;
		font-size: clamp(2.2rem, 10.5vw, 3rem);
	}

	.about-hero h1 span {
		margin-top: 8px;
		font-size: 0.65em;
		line-height: 1.18;
	}

	.about-hero-lead {
		font-size: 0.96rem;
		line-height: 1.65;
	}

	.about-actions {
		display: grid;
		grid-template-columns: 1fr;
		gap: 9px;
	}

	.about-actions .button {
		width: 100%;
		min-width: 0;
		padding-inline: 13px;
		font-size: 0.67rem;
	}

	.about-portrait {
		padding: 10px 6px 58px;
	}

	.about-portrait-frame {
		width: min(100%, 350px);
	}

	.about-portrait-frame img {
		object-position: 50% 0;
	}

	.about-stats {
		min-height: 0;
		gap: 7px;
		margin: -36px 10px 14px;
		border: 0;
		background: none;
		box-shadow: none;
	}

	.about-stat {
		min-height: 122px;
		flex-direction: column;
		gap: 8px;
		padding: 15px 7px 12px;
		border: 1px solid var(--about-line);
		border-radius: 11px;
		background: var(--about-panel);
		text-align: center;
	}

	.about-stat::after {
		display: none;
	}

	.about-stat-icon {
		width: 43px;
		height: 43px;
		flex-basis: 43px;
	}

	.about-stat-icon .icon {
		width: 23px;
		height: 23px;
	}

	.about-stat strong,
	.about-stat:nth-child(3) strong {
		font-size: 1.08rem;
	}

	.about-stat span {
		margin-top: 2px;
		font-size: 0.58rem;
	}

	.about-section {
		padding: 43px 0;
	}

	.about-section-heading {
		margin-bottom: 24px;
	}

	.about-section-heading h2,
	.about-story-copy h2 {
		font-size: 1.78rem;
	}

	.about-section-heading > p:last-child {
		font-size: 0.76rem;
	}

	.about-known-grid {
		grid-template-columns: 1fr;
		gap: 8px;
	}

	.about-known-card {
		display: grid;
		min-height: 0;
		grid-template-columns: 48px 1fr;
		gap: 3px 14px;
		padding: 18px;
	}

	.about-known-icon {
		width: 48px;
		height: 48px;
		margin: 0;
		grid-row: 1 / span 2;
	}

	.about-known-icon .icon {
		width: 27px;
		height: 27px;
	}

	.about-known-card h3 {
		margin: 2px 0 10px;
		font-size: 0.9rem;
	}

	.about-known-card ul {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 8px 10px;
		grid-column: 2;
	}

	.about-known-card li {
		gap: 5px;
		font-size: 0.63rem;
	}

	.about-story {
		padding-top: 47px;
	}

	.about-story-layout {
		grid-template-columns: 1fr;
		gap: 31px;
	}

	.about-story-copy > p:not(.about-section-label) {
		font-size: 0.77rem;
		line-height: 1.78;
	}

	.about-story-copy .about-story-closing {
		font-size: 0.81rem;
	}

	.about-industries {
		padding-top: 49px;
	}

	.about-industry-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 7px;
	}

	.about-industry-grid li {
		min-height: 79px;
		gap: 10px;
		padding: 13px 11px;
	}

	.about-industry-grid li > span {
		width: 38px;
		height: 38px;
		flex-basis: 38px;
	}

	.about-industry-grid .icon {
		width: 20px;
		height: 20px;
	}

	.about-industry-grid strong {
		font-size: 0.66rem;
	}

	.about-industry-grid li:last-child {
		grid-column: 1 / -1;
	}

	.about-contact-section {
		padding: 51px 0 47px;
	}

	.about-contact-card {
		grid-template-columns: 52px 1fr;
		gap: 16px;
		padding: 20px 17px;
	}

	.about-contact-icon {
		width: 52px;
		height: 52px;
	}

	.about-contact-icon .icon {
		width: 26px;
		height: 26px;
	}

	.about-contact-card h2 {
		font-size: 1.2rem;
	}

	.about-contact-card p {
		font-size: 0.69rem;
	}

	.about-contact-card .button {
		min-width: 0;
		grid-column: 1 / -1;
	}
}
