@font-face {
	font-display: swap;
	font-family: Plus Jakarta Sans;
	font-style: normal;
	font-weight: 400;
	src: url(../fonts/plus-jakarta-sans-v12-latin-regular.woff2) format("woff2")
}
@font-face {
	font-display: swap;
	font-family: Plus Jakarta Sans;
	font-style: normal;
	font-weight: 500;
	src: url(../fonts/plus-jakarta-sans-v12-latin-500.woff2) format("woff2")
}
@font-face {
	font-display: swap;
	font-family: Plus Jakarta Sans;
	font-style: normal;
	font-weight: 600;
	src: url(../fonts/plus-jakarta-sans-v12-latin-600.woff2) format("woff2")
}
@font-face {
	font-display: swap;
	font-family: Plus Jakarta Sans;
	font-style: normal;
	font-weight: 700;
	src: url(../fonts/plus-jakarta-sans-v12-latin-700.woff2) format("woff2")
}
@font-face {
	font-display: swap;
	font-family: Plus Jakarta Sans;
	font-style: normal;
	font-weight: 800;
	src: url(../fonts/plus-jakarta-sans-v12-latin-800.woff2) format("woff2")
}
@font-face {
	font-display: swap;
	font-family: Alex Brush;
	font-style: normal;
	font-weight: 400;
	src: url(../fonts/alex-brush-v23-latin-regular.woff2) format("woff2")
}
:root {
	--primary: #0052ff;
	--dark: #0f172a;
	--text: #1e293b;
	--light-text: #64748b;
	--bg-light: #f8fafc;
	--white: #fff;
	--red: #ef4444;
	--border-color: rgba(15, 23, 42, .08);
	--container-width: 1100px;
	--radius-md: 16px;
	--radius-lg: 24px;
	--transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1)
}
* {
	box-sizing: border-box;
	margin: 0;
	padding: 0
}
html {
	scroll-behavior: smooth
}
body {
	background-color: var(--white);
	color: var(--text);
	font-family: Plus Jakarta Sans, sans-serif;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased
}
.container {
	margin: 0 auto;
	max-width: var(--container-width);
	padding: 0 24px
}
.section-padding {
	padding: 120px 0
}
.bg-light {
	background-color: var(--bg-light)
}
.bg-dark {
	background-color: var(--dark);
	color: var(--white)
}
.text-center {
	text-align: center
}
h1, h2, h3 {
	color: var(--dark);
	font-weight: 800;
	line-height: 1.1
}
h1 {
	font-size: clamp(3rem, 7vw, 5rem);
	letter-spacing: -.03em
}
h2 {
	font-size: clamp(2rem, 4vw, 2.8rem);
	letter-spacing: -.02em
}
h3 {
	font-size: 1.35rem;
	letter-spacing: -.01em
}
.eyebrow, .text-accent {
	color: var(--primary)
}
.eyebrow {
	display: block;
	font-size: .85rem;
	font-weight: 700;
	letter-spacing: .12em;
	margin-bottom: 16px;
	text-transform: uppercase
}
.section-title {
	margin-bottom: 80px;
	max-width: 750px
}
.section-title p {
	color: var(--light-text);
	font-size: 1.2rem;
	margin-top: 20px
}
.header {
	backdrop-filter: blur(15px);
	background: hsla(0, 0%, 100%, .85);
	border-bottom: 1px solid rgba(0, 0, 0, .04);
	padding: 20px 0;
	position: sticky;
	top: 0;
	z-index: 1000
}
.header-inner {
	align-items: center;
	display: flex;
	justify-content: space-between
}
.logo {
	color: var(--dark);
	font-size: 1.4rem;
	font-weight: 800;
	letter-spacing: -.02em;
	text-decoration: none
}
.logo span {
	color: var(--primary)
}
.nav {
	align-items: center;
	display: flex;
	gap: 40px
}
.nav a:not(.btn) {
	color: var(--text);
	font-size: .95rem;
	font-weight: 600;
	text-decoration: none;
	transition: var(--transition)
}
.nav a:not(.btn):hover {
	color: var(--primary)
}
.btn {
	align-items: center;
	border: none;
	cursor: pointer;
	display: inline-flex;
	font-weight: 700;
	gap: 10px;
	justify-content: center;
	text-decoration: none;
	transition: var(--transition)
}
.btn-lg {
	background: linear-gradient(135deg, var(--primary) 0, #003ecc 100%);
	border-radius: 14px;
	box-shadow: 0 10px 25px -5px rgba(0, 82, 255, .4);
	color: var(--white);
	font-size: 1.05rem;
	padding: 20px 42px
}
.btn-lg:hover {
	box-shadow: 0 20px 35px -5px rgba(0, 82, 255, .5);
	transform: translateY(-4px)
}
.btn-lg i {
	transition: transform .3s ease
}
.btn-lg:hover i {
	transform: translateX(4px)
}
.btn-sm {
	background: var(--primary);
	border-radius: 10px;
	color: var(--white);
	font-size: .9rem;
	padding: 12px 24px
}
.btn-sm:hover {
	background: #003ecc;
	transform: translateY(-1px)
}
.btn-outline {
	background: transparent;
	border: 2px solid var(--white);
	border-radius: 12px;
	color: var(--white);
	padding: 16px 32px
}
.btn-outline:hover {
	background: var(--white);
	color: var(--dark);
	transform: translateY(-2px)
}
.hero {
	background-color: var(--white);
	overflow: hidden;
	padding: 130px 0 140px;
	position: relative
}
.hero-bg-pattern {
	background-image: linear-gradient(rgba(0, 82, 255, .04) 1px, transparent 0), linear-gradient(90deg, rgba(0, 82, 255, .04) 1px, transparent 0);
	background-position: 50%;
	background-size: 50px 50px;
	height: 100%;
	left: 0;
	mask-image: linear-gradient(180deg, #000 50%, transparent);
	-webkit-mask-image: linear-gradient(180deg, #000 50%, transparent);
	position: absolute;
	top: 0;
	width: 100%;
	z-index: 0
}
.hero-glow {
	background: radial-gradient(circle, rgba(0, 82, 255, .05) 0, transparent 65%);
	height: 700px;
	left: 50%;
	pointer-events: none;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 700px;
	z-index: 1
}
.relative-z {
	position: relative;
	z-index: 2
}
.hero-content {
	align-items: center;
	display: flex;
	flex-direction: column;
	margin: 0 auto;
	max-width: 850px
}
.hero h1 {
	margin-bottom: 24px
}
.hero-sub {
	color: var(--light-text);
	font-size: 1.25rem;
	line-height: 1.6;
	margin: 0 auto 35px;
	max-width: 650px
}
.trust-badge {
	align-items: center;
	background: var(--white);
	border: 1px solid rgba(0, 82, 255, .15);
	border-radius: 50px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, .02);
	color: var(--dark);
	display: inline-flex;
	font-size: .9rem;
	font-weight: 600;
	margin-bottom: 28px;
	padding: 8px 18px
}
.cta-center {
	flex-direction: column
}
.cta-center, .microcopy {
	align-items: center;
	display: flex
}
.microcopy {
	color: var(--light-text);
	font-size: .9rem;
	font-weight: 500;
	gap: 8px;
	justify-content: center;
	margin-top: 16px
}
.microcopy i {
	color: #10b981;
	font-size: 1.05rem
}
.center-title {
	margin: 0 auto 70px;
	max-width: 800px;
	text-align: center
}
.center-title p {
	margin-left: auto;
	margin-right: auto
}
.transformation-wrapper {
	display: flex;
	flex-direction: column;
	gap: 30px;
	margin: 0 auto;
	max-width: 1000px
}
.transform-row {
	align-items: flex-start;
	background: var(--white);
	border: 1px solid var(--border-color);
	border-radius: var(--radius-md);
	box-shadow: 0 4px 20px rgba(15, 23, 42, .02);
	display: flex;
	padding: 30px;
	transition: var(--transition)
}
.transform-row:hover {
	border-color: rgba(0, 82, 255, .2);
	box-shadow: 0 15px 35px rgba(0, 82, 255, .06);
	transform: translateY(-3px)
}
.transform-problem {
	padding-right: 20px
}
.transform-problem, .transform-solution {
	align-items: flex-start;
	display: flex;
	flex: 1;
	gap: 20px
}
.transform-solution {
	padding-left: 20px
}
.transform-arrow {
	align-items: center;
	background: transparent;
	border: none;
	color: var(--primary);
	display: flex;
	flex-shrink: 0;
	font-size: 1.4rem;
	justify-content: center;
	margin-top: 12px;
	opacity: .4;
	width: 40px
}
.mobile-arrow {
	display: none !important
}
.t-icon {
	align-items: center;
	border-radius: 12px;
	display: flex;
	flex-shrink: 0;
	font-size: 1.25rem;
	height: 48px;
	justify-content: center;
	width: 48px
}
.t-icon.red {
	background: #fef2f2;
	color: var(--red)
}
.t-icon.blue {
	background: rgba(0, 82, 255, .08);
	color: var(--primary)
}
.transform-problem h3, .transform-solution h3 {
	color: var(--dark);
	font-size: 1.2rem;
	margin-bottom: 8px
}
.transform-problem p {
	color: var(--light-text);
	font-size: .95rem;
	line-height: 1.5
}
.transform-solution p {
	color: var(--text);
	font-size: .95rem;
	line-height: 1.5
}
@media (max-width:850px) {
	.transform-row {
		align-items: flex-start;
		flex-direction: column;
		gap: 20px;
		padding: 25px
	}
	.transform-problem, .transform-solution {
		padding: 0
	}
	.transform-arrow {
		align-self: center;
		background: transparent;
		border: none;
		height: auto
	}
	.desktop-arrow {
		display: none !important
	}
	.mobile-arrow {
		color: var(--primary);
		display: block !important;
		font-size: 1.5rem
	}
}
.bg-dark {
	background-color: #0b1120;
	color: #f1f5f9
}
.text-light-premium {
	color: #f8fafc !important;
	/* !important überschreibt die .section-title p Regel */
	font-weight: 400 !important
}
.eyebrow-white {
	color: #cbd5e1
}
.referenz-img-note {
	align-items: center;
	color: #94a3b8;
	display: inline-flex;
	font-size: .8rem !important;
	font-weight: 400;
	gap: 7px;
	line-height: 1.4;
	margin-top: 18px;
	opacity: .85
}
.referenz-img-note i {
	font-size: .85rem;
	opacity: .8
}
.carousel-wrapper {
	margin: 0 auto;
	max-width: 1400px;
	padding: 0 80px;
	position: relative
}
.carousel-wrapper:before {
	background: radial-gradient(circle, rgba(0, 82, 255, .12) 0, transparent 65%);
	content: "";
	height: 85%;
	left: 50%;
	pointer-events: none;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 85%;
	z-index: -1
}
.carousel-track {
	display: flex;
	gap: 20px;
	overflow-x: auto;
	scroll-behavior: smooth;
	scroll-snap-type: x mandatory;
	-ms-overflow-style: none;
	overscroll-behavior-x: contain;
	scrollbar-width: none
}
.carousel-track::-webkit-scrollbar {
	display: none
}
.carousel-slide {
	background: hsla(0, 0%, 100%, .03);
	border: 1px solid hsla(0, 0%, 100%, .08);
	border-radius: var(--radius-lg);
	display: flex;
	flex: 0 0 100%;
	flex-direction: column;
	overflow: hidden;
	scroll-snap-align: center;
	transition: var(--transition)
}
.carousel-slide:hover {
	border-color: rgba(0, 82, 255, .35);
	box-shadow: 0 30px 70px -25px rgba(0, 82, 255, .45)
}
.slide-visual {
	background: #1e293b;
	border-bottom: 1px solid hsla(0, 0%, 100%, .08);
	position: relative;
	width: 100%
}
.browser-bar {
	align-items: center;
	background: #0f172a;
	border-bottom: 1px solid hsla(0, 0%, 100%, .05);
	display: flex;
	justify-content: space-between;
	padding: 16px 24px
}
.browser-dots {
	display: flex;
	gap: 8px;
	width: 100px
}
.browser-dots span {
	background: #475569;
	border-radius: 50%;
	height: 12px;
	width: 12px
}
.browser-address {
	align-items: center;
	background: hsla(0, 0%, 100%, .05);
	border-radius: 6px;
	color: #cbd5e1;
	display: flex;
	flex: 1;
	font-size: .85rem;
	gap: 8px;
	justify-content: center;
	max-width: 400px;
	padding: 6px 15px
}
.browser-address i {
	font-size: .75rem
}
.browser-action {
	display: flex;
	justify-content: flex-end;
	width: auto
}
.browser-btn {
	align-items: center;
	background: linear-gradient(135deg, var(--primary) 0, #003ecc 100%);
	border-radius: 8px;
	box-shadow: 0 4px 15px -3px rgba(0, 82, 255, .4);
	color: var(--white) !important;
	display: inline-flex;
	font-size: .85rem;
	font-weight: 700;
	gap: 8px;
	padding: 10px 20px;
	text-decoration: none;
	transition: var(--transition)
}
.browser-btn:hover {
	box-shadow: 0 8px 20px -3px rgba(0, 82, 255, .5);
	transform: translateY(-2px)
}
.portfolio-img-wrap {
	cursor: pointer;
	height: clamp(600px, 80vh, 950px);
	overflow-x: hidden;
	overflow-y: auto;
	scrollbar-color: hsla(0, 0%, 100%, .2) transparent;
	scrollbar-width: thin;
	-webkit-overflow-scrolling: touch
}
.portfolio-img-wrap img {
	display: block;
	height: auto;
	width: 100%
}
.portfolio-img-wrap::-webkit-scrollbar {
	width: 10px
}
.portfolio-img-wrap::-webkit-scrollbar-track {
	background: #0f172a;
	border-left: 1px solid hsla(0, 0%, 100%, .05)
}
.portfolio-img-wrap::-webkit-scrollbar-thumb {
	background-color: #334155;
	border: 2px solid #0f172a;
	border-radius: 10px
}
.portfolio-img-wrap::-webkit-scrollbar-thumb:hover {
	background-color: var(--primary)
}
.visual-hints {
	bottom: 30px;
	display: flex;
	gap: 15px;
	justify-content: center;
	left: 0;
	pointer-events: none;
	position: absolute;
	transition: opacity .4s ease;
	width: 100%
}
.slide-visual:hover .visual-hints {
	opacity: .5
}
.hint-badge-clear {
	align-items: center;
	backdrop-filter: blur(4px);
	background: rgba(15, 23, 42, .8);
	border: 1px solid hsla(0, 0%, 100%, .08);
	border-radius: 50px;
	color: #f1f5f9;
	display: inline-flex;
	font-size: .8rem;
	font-weight: 700;
	gap: 8px;
	letter-spacing: .05em;
	padding: 8px 16px;
	text-transform: uppercase
}
.hint-open {
	background: rgba(0, 82, 255, .78);
	border: 1px solid rgba(96, 165, 250, .55);
	color: var(--white)
}
@keyframes bounce-premium {
	0%, to {
		transform: translateY(0)
	}
	50% {
		transform: translateY(-3px)
	}
}
.bounce-icon {
	animation: bounce-premium 1.5s ease-in-out infinite
}
.slide-content {
	align-items: flex-start;
	display: flex;
	flex-direction: column;
	padding: 50px 60px;
	width: 100%
}
.portfolio-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 20px
}
.portfolio-tags .tag {
	background: rgba(0, 82, 255, .1);
	border: 1px solid rgba(0, 82, 255, .2);
	border-radius: 50px;
	color: #60a5fa;
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .05em;
	padding: 6px 12px;
	text-transform: uppercase
}
.slide-content h3 {
	color: var(--white);
	font-size: 2rem;
	margin-bottom: 15px
}
.project-story {
	display: grid;
	gap: 40px;
	grid-template-columns: 1fr 1fr;
	margin-top: 15px;
	width: 100%
}
.story-block {
	background: hsla(0, 0%, 100%, .02);
	border: 1px solid hsla(0, 0%, 100%, .04);
	border-radius: 12px;
	padding: 24px
}
.story-block h4 {
	align-items: center;
	color: #94a3b8;
	display: flex;
	font-size: .9rem;
	gap: 10px;
	letter-spacing: .08em;
	margin-bottom: 12px;
	text-transform: uppercase
}
.story-block.pain h4 i {
	color: var(--red)
}
.story-block.success h4 i {
	color: #10b981
}
.story-block p {
	color: #cbd5e1;
	font-size: 1rem;
	line-height: 1.6;
	margin-bottom: 0
}
.slide-content p + a.btn {
	display: none
}
.carousel-btn {
	align-items: center;
	backdrop-filter: blur(2px);
	background: hsla(0, 0%, 100%, .03);
	border: 2px solid hsla(0, 0%, 100%, .08);
	border-radius: 50%;
	color: #f1f5f9;
	cursor: pointer;
	display: flex;
	font-size: 1.2rem;
	height: 50px;
	justify-content: center;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	transition: var(--transition);
	width: 50px;
	z-index: 10
}
.carousel-btn:hover {
	background: var(--primary);
	border-color: var(--primary);
	box-shadow: 0 4px 15px rgba(0, 82, 255, .4);
	color: var(--white);
	transform: translateY(-50%) scale(1.05)
}
.carousel-btn.prev {
	left: 0
}
.carousel-btn.next {
	right: 0
}
@media (max-width:850px) {
	.carousel-wrapper {
		padding: 0
	}
	.portfolio-img-wrap {
		height: clamp(420px, 64vh, 600px)
	}
	.slide-content {
		padding: 30px
	}
	.project-story {
		gap: 20px;
		grid-template-columns: 1fr
	}
	.carousel-btn {
		height: 40px;
		width: 40px
	}
	.carousel-btn.prev {
		left: -10px
	}
	.carousel-btn.next {
		right: -10px
	}
	.browser-dots {
		display: none
	}
	.browser-action {
		width: auto
	}
	.browser-address {
		max-width: none
	}
	.visual-hints {
		align-items: center;
		bottom: 20px;
		flex-direction: column;
		gap: 10px
	}
	.hint-badge-clear {
		font-size: .8rem;
		padding: 6px 12px
	}
	.referenz-img-note {
		justify-content: center;
		text-align: center
	}
}
.about-intro {
	color: var(--text);
	font-size: 1.2rem;
	margin-bottom: 60px;
	max-width: 800px
}
.expertise-container {
	display: grid;
	gap: 40px;
	grid-template-columns: repeat(3, 1fr)
}
.exp-group {
	background: var(--bg-light);
	border: 1px solid var(--border-color);
	border-radius: var(--radius-md);
	padding: 40px 30px
}
.exp-header {
	align-items: center;
	display: flex;
	gap: 14px;
	margin-bottom: 25px
}
.exp-header i {
	color: var(--primary);
	font-size: 1.4rem
}
.exp-list {
	list-style: none
}
.exp-list li {
	color: var(--text);
	font-size: .95rem;
	line-height: 1.5;
	margin-bottom: 18px;
	padding-left: 20px;
	position: relative
}
.exp-list li:before {
	color: var(--primary);
	content: "→";
	font-weight: 800;
	left: 0;
	position: absolute
}
.exp-list li strong {
	color: var(--dark)
}
.cta-text {
	color: var(--light-text);
	font-size: 1.25rem;
	margin: 20px auto 0;
	max-width: 700px
}
.footer {
	border-top: 1px solid var(--bg-light);
	padding: 50px 0
}
.footer-wrap {
	align-items: center;
	color: var(--light-text);
	display: flex;
	font-size: .9rem;
	justify-content: space-between
}
.f-links a {
	color: var(--light-text);
	margin-left: 24px;
	text-decoration: none;
	transition: var(--transition)
}
.f-links a:hover {
	color: var(--primary)
}
@media (max-width:992px) {
	.expertise-container, .problem-grid, .ref-wrapper, .solution-list {
		grid-template-columns: 1fr
	}
	.solution-list {
		gap: 35px
	}
	.hero {
		padding: 90px 0 100px
	}
	.section-padding {
		padding: 80px 0
	}
	.ref-wrapper {
		gap: 50px
	}
}
@media (max-width:768px) {
	.footer-wrap {
		flex-direction: column;
		gap: 20px;
		text-align: center
	}
	.f-links a {
		margin: 0 12px
	}
}
.live-modal {
	align-items: center;
	display: flex;
	inset: 0;
	justify-content: center;
	opacity: 0;
	padding: 24px;
	position: fixed;
	transition: opacity .25s ease, visibility .25s ease;
	visibility: hidden;
	z-index: 3000
}
.live-modal.is-open {
	opacity: 1;
	visibility: visible
}
.live-modal-backdrop {
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	background: rgba(2, 6, 23, .72);
	cursor: pointer;
	inset: 0;
	position: absolute
}
.live-modal-card {
	background: #0f1b33;
	border: 1px solid hsla(0, 0%, 100%, .1);
	border-radius: var(--radius-lg);
	box-shadow: 0 30px 70px -20px rgba(0, 0, 0, .6);
	max-width: 430px;
	padding: 40px 36px;
	position: relative;
	text-align: center;
	transform: translateY(12px) scale(.97);
	transition: transform .28s cubic-bezier(.4, 0, .2, 1);
	width: 100%;
	z-index: 1
}
.live-modal.is-open .live-modal-card {
	transform: translateY(0) scale(1)
}
.live-modal-icon {
	align-items: center;
	background: linear-gradient(135deg, var(--primary) 0, #003ecc 100%);
	border-radius: 16px;
	box-shadow: 0 10px 25px -5px rgba(0, 82, 255, .5);
	color: var(--white);
	display: flex;
	font-size: 1.4rem;
	height: 60px;
	justify-content: center;
	margin: 0 auto 22px;
	width: 60px
}
.live-modal-title {
	color: var(--white);
	font-size: 1.5rem;
	margin-bottom: 12px
}
.live-modal-text {
	color: #cbd5e1;
	font-size: .98rem;
	line-height: 1.6;
	margin-bottom: 22px
}
.live-modal-url {
	align-items: center;
	background: hsla(0, 0%, 100%, .05);
	border: 1px solid hsla(0, 0%, 100%, .08);
	border-radius: 10px;
	color: #e2e8f0;
	display: inline-flex;
	font-size: .9rem;
	gap: 8px;
	margin-bottom: 28px;
	padding: 10px 18px;
	word-break: break-all
}
.live-modal-url i {
	color: #10b981;
	flex-shrink: 0;
	font-size: .8rem
}
.live-modal-actions {
	display: flex;
	gap: 12px;
	justify-content: center
}
.live-modal-btn {
	align-items: center;
	border: none;
	border-radius: 12px;
	cursor: pointer;
	display: inline-flex;
	flex: 1;
	font-family: inherit;
	font-size: .95rem;
	font-weight: 700;
	gap: 8px;
	justify-content: center;
	padding: 14px 20px;
	text-decoration: none;
	transition: var(--transition)
}
.live-modal-cancel {
	background: transparent;
	border: 1px solid hsla(0, 0%, 100%, .15);
	color: #cbd5e1
}
.live-modal-cancel:hover {
	background: hsla(0, 0%, 100%, .06);
	color: var(--white)
}
.live-modal-open {
	background: linear-gradient(135deg, var(--primary) 0, #003ecc 100%);
	box-shadow: 0 10px 25px -5px rgba(0, 82, 255, .4);
	color: var(--white)
}
.live-modal-open:hover {
	box-shadow: 0 16px 30px -5px rgba(0, 82, 255, .5);
	transform: translateY(-2px)
}
.live-modal-open i {
	transition: transform .3s ease
}
.live-modal-open:hover i {
	transform: translateX(3px)
}
@media (max-width:480px) {
	.live-modal-card {
		padding: 32px 24px
	}
	.live-modal-actions {
		flex-direction: column-reverse
	}
}
#referenz h2, .bg-dark h2, .bg-dark h3 {
	color: #fff !important
}
.about-section {
	background: radial-gradient(circle at 18% 45%, rgba(0, 82, 255, .045) 0, transparent 30%), var(--white);
	overflow: hidden;
	position: relative
}
.about-heading {
	margin: 0 auto 58px;
	max-width: 860px
}
.about-heading .eyebrow {
	margin-bottom: 14px
}
.about-heading h2 {
	font-size: clamp(2.45rem, 4.4vw, 4rem);
	letter-spacing: -.045em
}
.about-layout {
	align-items: center;
	display: grid;
	gap: 72px;
	grid-template-columns: 470px 520px;
	justify-content: center;
	margin: 0 auto;
	max-width: 1080px
}
.about-card {
	background: var(--white);
	border: 1px solid var(--border-color);
	border-radius: 28px;
	box-shadow: 0 30px 70px -38px rgba(15, 23, 42, .42);
	padding: 32px 32px 26px;
	position: relative
}
.about-card:before {
	background: rgba(0, 82, 255, .045);
	border-radius: 50%;
	content: "";
	height: 230px;
	left: -82px;
	position: absolute;
	top: 90px;
	width: 230px;
	z-index: 0
}
.about-card-pattern {
	background-image: radial-gradient(rgba(0, 82, 255, .55) 1.35px, transparent 0);
	background-size: 14px 14px;
	height: 132px;
	left: -58px;
	opacity: .32;
	position: absolute;
	top: 42px;
	width: 104px;
	z-index: 0
}
.about-photo-wrap {
	background: #fff6ea;
	border-radius: 22px;
	box-shadow: inset 0 0 0 1px rgba(15, 23, 42, .04);
	overflow: hidden;
	position: relative;
	z-index: 2
}
.about-photo-wrap img {
	aspect-ratio: 1/1;
	display: block;
	object-fit: cover;
	object-position: center top;
	width: 100%
}
.about-mini-badge {
	align-items: center;
	backdrop-filter: blur(10px);
	background: hsla(0, 0%, 100%, .97);
	border: 1px solid rgba(15, 23, 42, .08);
	border-radius: 16px;
	box-shadow: 0 16px 34px rgba(15, 23, 42, .13);
	color: var(--dark);
	display: inline-flex;
	font-size: .86rem;
	font-weight: 700;
	gap: 11px;
	line-height: 1.3;
	padding: 14px 17px;
	position: absolute;
	z-index: 4
}
.about-mini-badge i {
	color: var(--primary);
	flex-shrink: 0;
	font-size: 1.15rem
}
.about-mini-badge strong {
	color: var(--primary);
	display: block;
	font-weight: 800
}
.about-badge-experience {
	left: -36px;
	top: 36%
}
.about-badge-local {
	right: -38px;
	top: 56%
}
.about-region {
	align-items: center;
	border-top: 1px solid var(--border-color);
	display: flex;
	gap: 16px;
	margin-top: 26px;
	padding-top: 24px;
	position: relative;
	z-index: 2
}
.about-region-icon {
	align-items: center;
	background: rgba(0, 82, 255, .08);
	border-radius: 15px;
	color: var(--primary);
	display: flex;
	flex-shrink: 0;
	font-size: 1.1rem;
	height: 44px;
	justify-content: center;
	width: 44px
}
.about-region strong {
	color: var(--primary);
	display: block;
	font-size: 1rem;
	line-height: 1.25;
	margin-bottom: 4px
}
.about-region span {
	color: var(--light-text);
	display: block;
	font-size: .9rem;
	line-height: 1.45
}
.about-text {
	max-width: 520px
}
.about-story p {
	color: var(--text);
	font-size: 1.02rem;
	line-height: 1.72;
	margin-bottom: 19px
}
.about-story p:last-child {
	margin-bottom: 0
}
.about-signature {
	display: flex;
	flex-direction: column;
	margin-top: 32px
}
.sig-name {
	color: var(--primary);
	font-family: Alex Brush, cursive;
	font-size: 3.2rem;
	line-height: .9
}
.sig-role {
	color: var(--light-text);
	font-size: .92rem;
	font-weight: 500;
	margin-top: 8px
}
.about-trust {
	gap: 16px;
	max-width: 900px
}
.trust-chip {
	border-radius: 15px;
	box-shadow: 0 14px 32px -26px rgba(15, 23, 42, .42);
	font-size: .9rem;
	font-weight: 700;
	padding: 13px 18px
}
.trust-chip i {
	font-size: 1rem
}
.trust-chip:hover {
	box-shadow: 0 18px 38px -26px rgba(0, 82, 255, .35)
}
@media (max-width:1100px) {
	.about-layout {
		gap: 56px;
		grid-template-columns: minmax(360px, 440px) minmax(0, 500px)
	}
	.about-badge-experience {
		left: -22px
	}
	.about-badge-local {
		right: -22px
	}
	.about-trust {
		max-width: 820px
	}
}
@media (max-width:900px) {
	.about-heading {
		margin-bottom: 44px
	}
	.about-layout {
		gap: 44px;
		grid-template-columns: 1fr;
		max-width: 560px
	}
	.about-card {
		padding: 26px 26px 24px
	}
	.about-text {
		max-width: none;
		text-align: center
	}
	.about-signature {
		align-items: center
	}
	.about-trust {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		margin-top: 50px;
		max-width: 560px
	}
}
@media (max-width:560px) {
	.about-card {
		position: relative
	}
	.about-mini-badge {
		background: hsla(0, 0%, 100%, .97);
		border-radius: 14px !important;
		box-shadow: 0 12px 24px rgba(15, 23, 42, .1) !important;
		font-size: .8rem;
		justify-content: flex-start !important;
		line-height: 1.25;
		margin-top: 0 !important;
		max-width: 170px;
		padding: 10px 12px !important;
		position: absolute !important;
		width: auto !important
	}
	.about-mini-badge i {
		font-size: 1rem
	}
	.about-badge-experience {
		bottom: auto !important;
		left: 12px !important;
		right: auto !important;
		top: 41% !important
	}
	.about-badge-local {
		bottom: auto !important;
		left: auto !important;
		right: 12px !important;
		top: 58% !important
	}
	.about-region {
		margin-top: 22px;
		padding-top: 22px
	}
	.about-trust {
		display: grid;
		gap: 12px;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		margin-top: 44px;
		max-width: 100%
	}
	.trust-chip {
		border-radius: 16px;
		font-size: .86rem;
		gap: 8px;
		justify-content: center;
		line-height: 1.25;
		min-height: 66px;
		padding: 13px 10px;
		text-align: center;
		white-space: normal;
		width: 100%
	}
	.trust-chip i {
		flex-shrink: 0;
		font-size: .95rem
	}
}
.services-section {
	background: radial-gradient(circle at 78% 8%, rgba(0, 82, 255, .045) 0, transparent 30%), var(--bg-light);
	overflow: hidden;
	position: relative
}
.services-heading {
	margin: 0 auto 58px;
	max-width: 980px
}
.services-heading h2 {
	font-size: clamp(2.2rem, 3.8vw, 3.45rem);
	letter-spacing: -.045em;
	margin-left: auto;
	margin-right: auto;
	max-width: 980px
}
.services-heading .text-accent {
	white-space: nowrap
}
.services-heading p {
	margin-left: auto;
	margin-right: auto;
	max-width: 620px
}
.services-grid {
	display: grid;
	gap: 22px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin: 0 auto;
	max-width: 1120px
}
.service-card {
	background: var(--white);
	border: 1px solid var(--border-color);
	border-radius: 22px;
	box-shadow: 0 18px 44px -34px rgba(15, 23, 42, .38);
	display: flex;
	flex-direction: column;
	min-height: 340px;
	padding: 28px;
	position: relative;
	transition: var(--transition)
}
.service-card:hover {
	border-color: rgba(0, 82, 255, .2);
	box-shadow: 0 28px 60px -36px rgba(0, 82, 255, .35);
	transform: translateY(-5px)
}
.service-icon {
	align-items: center;
	background: linear-gradient(135deg, rgba(0, 82, 255, .1), rgba(0, 82, 255, .035));
	border-radius: 18px;
	color: var(--primary);
	display: flex;
	flex-shrink: 0;
	font-size: 1.55rem;
	height: 64px;
	justify-content: center;
	margin-bottom: 22px;
	width: 64px
}
.service-content h3 {
	color: var(--dark);
	font-size: 1.15rem;
	letter-spacing: -.02em;
	margin-bottom: 13px
}
.service-content p {
	color: var(--text);
	font-size: .94rem;
	line-height: 1.68
}
.service-included {
	border-top: 1px solid var(--border-color);
	color: var(--light-text);
	font-size: .87rem;
	line-height: 1.55;
	margin-top: auto;
	padding-top: 18px
}
.service-included strong {
	color: var(--primary);
	font-weight: 800
}
.process-box {
	background: var(--white);
	border: 1px solid var(--border-color);
	border-radius: 24px;
	box-shadow: 0 20px 50px -38px rgba(15, 23, 42, .45);
	margin: 42px auto 0;
	max-width: 1120px;
	padding: 34px
}
.process-header {
	margin: 0 auto 30px;
	max-width: 620px;
	text-align: center
}
.process-header .eyebrow {
	font-size: .78rem;
	margin-bottom: 10px
}
.process-header h3 {
	color: var(--dark);
	font-size: clamp(1.35rem, 2vw, 1.8rem);
	letter-spacing: -.025em
}
.process-steps {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	position: relative
}
.process-steps:before {
	background: linear-gradient(90deg, rgba(0, 82, 255, .12), rgba(0, 82, 255, .24), rgba(0, 82, 255, .12));
	content: "";
	height: 2px;
	left: 8%;
	position: absolute;
	right: 8%;
	top: 31px;
	z-index: 0
}
.process-step {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 12px;
	min-width: 0;
	position: relative;
	text-align: center;
	z-index: 1
}
.process-step span {
	align-items: center;
	background: #eef4ff;
	border: 6px solid var(--white);
	border-radius: 50%;
	box-shadow: 0 10px 24px -18px rgba(0, 82, 255, .5);
	color: var(--primary);
	display: inline-flex;
	font-size: .95rem;
	font-weight: 800;
	height: 62px;
	justify-content: center;
	width: 62px
}
.process-step strong {
	color: var(--dark);
	font-size: .86rem;
	line-height: 1.3;
	max-width: 120px
}
@media (max-width:1050px) {
	.services-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr))
	}
	.process-steps {
		gap: 22px 18px;
		grid-template-columns: repeat(3, minmax(0, 1fr))
	}
	.process-steps:before {
		display: none
	}
	.process-step {
		background: var(--bg-light);
		border-radius: 16px;
		padding: 18px 14px
	}
	.process-step span {
		border: none;
		height: 46px;
		width: 46px
	}
}
@media (max-width:700px) {
	.services-heading {
		margin-bottom: 40px
	}
	.services-heading .text-accent {
		white-space: normal
	}
	.services-grid {
		grid-template-columns: 1fr
	}
	.service-card {
		min-height: auto;
		padding: 24px
	}
	.process-box {
		border-radius: 22px;
		margin-top: 32px;
		padding: 24px 18px
	}
	.process-header {
		margin-bottom: 24px
	}
	.process-steps {
		display: flex;
		flex-direction: column;
		gap: 14px
	}
	.process-steps:before {
		display: none
	}
	.process-step {
		background: var(--bg-light);
		border-radius: 16px;
		flex-direction: row;
		gap: 14px;
		justify-content: flex-start;
		padding: 16px;
		position: relative;
		text-align: left
	}
	.process-step:not(:last-child):after {
		background: rgba(0, 82, 255, .18);
		bottom: -14px;
		content: "";
		height: 14px;
		left: 38px;
		position: absolute;
		width: 2px
	}
	.process-step span {
		border: none;
		flex-shrink: 0;
		height: 44px;
		width: 44px
	}
	.process-step strong {
		font-size: .95rem;
		max-width: none
	}
}
.faq-section {
	background: var(--white);
	overflow: hidden;
	position: relative
}
.faq-heading {
	margin-bottom: 52px
}
.faq-heading h2 {
	font-size: clamp(2.15rem, 4vw, 3.45rem);
	letter-spacing: -.045em
}
.faq-heading p {
	margin-left: auto;
	margin-right: auto;
	max-width: 720px
}
.faq-list {
	display: grid;
	gap: 14px;
	margin: 0 auto;
	max-width: 880px
}
.faq-item {
	background: var(--white);
	border: 1px solid var(--border-color);
	border-radius: 18px;
	box-shadow: 0 14px 38px -34px rgba(15, 23, 42, .4);
	overflow: hidden;
	transition: var(--transition)
}
.faq-item:hover {
	border-color: rgba(0, 82, 255, .18);
	box-shadow: 0 18px 44px -34px rgba(0, 82, 255, .28)
}
.faq-item summary {
	align-items: center;
	color: var(--dark);
	cursor: pointer;
	display: flex;
	font-size: 1rem;
	font-weight: 800;
	gap: 18px;
	justify-content: space-between;
	list-style: none;
	padding: 22px 26px
}
.faq-item summary::-webkit-details-marker {
	display: none
}
.faq-item summary:after {
	align-items: center;
	background: rgba(0, 82, 255, .08);
	border-radius: 50%;
	color: var(--primary);
	content: "+";
	display: inline-flex;
	flex-shrink: 0;
	font-weight: 800;
	height: 30px;
	justify-content: center;
	transition: var(--transition);
	width: 30px
}
.faq-item[open] summary:after {
	background: var(--primary);
	color: var(--white);
	content: "−"
}
.faq-item p {
	color: var(--light-text);
	font-size: .98rem;
	line-height: 1.68;
	padding: 0 26px 24px
}
.faq-item p strong {
	color: var(--dark);
	font-weight: 800
}
@media (max-width:560px) {
	.faq-heading {
		margin-bottom: 40px
	}
	.faq-item {
		border-radius: 16px
	}
	.faq-item summary {
		font-size: .95rem;
		line-height: 1.35;
		padding: 19px 20px
	}
	.faq-item summary:after {
		height: 28px;
		width: 28px
	}
	.faq-item p {
		font-size: .94rem;
		padding: 0 20px 22px
	}
}
.project-request-section {
	background: #0b1120;
	color: var(--white);
	overflow: hidden;
	position: relative
}
.project-request-bg {
	background: radial-gradient(circle at 20% 20%, rgba(0, 82, 255, .22) 0, transparent 34%), radial-gradient(circle at 82% 18%, rgba(96, 165, 250, .13) 0, transparent 28%), linear-gradient(180deg, #0b1120, #0f172a);
	inset: 0;
	position: absolute;
	z-index: 0
}
.project-request-bg:after {
	background-image: linear-gradient(hsla(0, 0%, 100%, .035) 1px, transparent 0), linear-gradient(90deg, hsla(0, 0%, 100%, .035) 1px, transparent 0);
	background-size: 54px 54px;
	content: "";
	inset: 0;
	mask-image: linear-gradient(180deg, #000, transparent 85%);
	-webkit-mask-image: linear-gradient(180deg, #000, transparent 85%);
	position: absolute
}
.project-request-heading {
	margin: 0 auto 44px;
	max-width: 860px
}
.project-request-heading .eyebrow {
	margin-bottom: 16px
}
.project-request-heading h2 {
	color: var(--white);
	font-size: clamp(2.4rem, 5vw, 4.25rem);
	letter-spacing: -.05em;
	margin-bottom: 20px
}
.project-request-heading p {
	color: #cbd5e1;
	font-size: 1.15rem;
	line-height: 1.65;
	margin: 0 auto;
	max-width: 720px
}
.project-request-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	justify-content: center;
	margin-top: 28px
}
.project-request-chips span {
	align-items: center;
	backdrop-filter: blur(8px);
	background: hsla(0, 0%, 100%, .06);
	border: 1px solid hsla(0, 0%, 100%, .09);
	border-radius: 999px;
	color: #f8fafc;
	display: inline-flex;
	font-size: .92rem;
	font-weight: 700;
	gap: 9px;
	padding: 10px 16px
}
.project-request-chips i {
	color: #10b981
}
.tally-form-shell {
	background: var(--white);
	border: 1px solid hsla(0, 0%, 100%, .12);
	border-radius: 28px;
	box-shadow: 0 35px 90px -45px rgba(0, 0, 0, .75);
	margin: 0 auto;
	max-width: 980px;
	padding: clamp(14px, 2vw, 24px)
}
.tally-placeholder {
	background: linear-gradient(135deg, rgba(0, 82, 255, .055), hsla(0, 0%, 100%, .95)), var(--bg-light);
	border: 1px dashed rgba(0, 82, 255, .35);
	border-radius: 22px;
	color: var(--dark);
	flex-direction: column;
	min-height: 640px;
	padding: 34px;
	text-align: center
}
.tally-placeholder, .tally-placeholder-icon {
	align-items: center;
	display: flex;
	justify-content: center
}
.tally-placeholder-icon {
	background: rgba(0, 82, 255, .09);
	border-radius: 24px;
	color: var(--primary);
	font-size: 1.8rem;
	height: 78px;
	margin-bottom: 24px;
	width: 78px
}
.tally-placeholder h3 {
	font-size: 1.55rem;
	margin-bottom: 10px
}
.tally-placeholder p {
	color: var(--light-text);
	margin-bottom: 18px;
	max-width: 380px
}
.tally-placeholder span {
	align-items: center;
	background: var(--white);
	border: 1px solid rgba(0, 82, 255, .15);
	border-radius: 999px;
	color: var(--primary);
	display: inline-flex;
	font-size: .85rem;
	font-weight: 800;
	justify-content: center;
	padding: 9px 16px
}
.project-request-note {
	color: #94a3b8;
	font-size: .9rem;
	line-height: 1.6;
	margin: 24px auto 0;
	max-width: 720px;
	text-align: center
}
@media (max-width:700px) {
	.faq-heading {
		margin-bottom: 40px
	}
	.faq-item summary {
		font-size: .95rem;
		padding: 19px 20px
	}
	.faq-item p {
		font-size: .94rem;
		padding: 0 20px 22px
	}
	.project-request-heading {
		margin-bottom: 34px
	}
	.project-request-heading p {
		font-size: 1rem
	}
	.project-request-chips {
		align-items: stretch;
		flex-direction: column;
		margin-left: auto;
		margin-right: auto;
		max-width: 360px
	}
	.project-request-chips span {
		justify-content: center;
		text-align: center
	}
	.tally-form-shell {
		border-radius: 22px;
		padding: 10px
	}
	.tally-placeholder {
		border-radius: 18px;
		min-height: 520px;
		padding: 28px 18px
	}
	.project-request-note {
		font-size: .84rem
	}
}
.slide-content h3 {
	margin-bottom: 6px
}
.slide-subtitle {
	color: #94a3b8;
	font-size: 1.05rem;
	font-weight: 500;
	line-height: 1.5;
	margin-bottom: 22px
}
.case-quote {
	background: rgba(0, 82, 255, .06);
	border: 1px solid rgba(0, 82, 255, .18);
	border-left: 3px solid var(--primary);
	border-radius: 14px;
	margin-top: 32px;
	padding: 26px 30px;
	position: relative;
	width: 100%
}
.case-quote:before {
	color: rgba(96, 165, 250, .28);
	content: "\201C";
	font-family: Georgia, Times New Roman, serif;
	font-size: 3.2rem;
	left: 16px;
	line-height: 1;
	pointer-events: none;
	position: absolute;
	top: 4px
}
.case-quote blockquote {
	color: #e2e8f0;
	font-size: 1.05rem;
	font-style: italic;
	line-height: 1.7;
	margin: 0 0 18px;
	position: relative;
	z-index: 1
}
.case-quote figcaption {
	align-items: center;
	display: flex;
	gap: 12px
}
.case-quote .quote-avatar {
	align-items: center;
	background: linear-gradient(135deg, var(--primary) 0, #003ecc 100%);
	border-radius: 50%;
	color: var(--white);
	display: inline-flex;
	flex-shrink: 0;
	font-size: 1rem;
	height: 44px;
	justify-content: center;
	width: 44px
}
.case-quote .quote-author {
	display: flex;
	flex-direction: column;
	line-height: 1.3
}
.case-quote .quote-author strong {
	color: var(--white);
	font-size: .95rem;
	font-weight: 700
}
.case-quote .quote-author span {
	color: #94a3b8;
	font-size: .85rem
}
.case-stats {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 30px;
	width: 100%
}
.case-stat {
	background: hsla(0, 0%, 100%, .03);
	border: 1px solid hsla(0, 0%, 100%, .06);
	border-radius: 12px;
	flex: 1 1 140px;
	padding: 18px 20px;
	text-align: center
}
.case-stat .stat-num {
	color: var(--white);
	display: block;
	font-size: 1.7rem;
	font-weight: 800;
	line-height: 1.1
}
.case-stat .stat-label {
	color: #94a3b8;
	display: block;
	font-size: .82rem;
	margin-top: 6px
}
.case-badge {
	align-items: center;
	background: rgba(0, 82, 255, .1);
	border: 1px solid rgba(0, 82, 255, .2);
	border-radius: 50px;
	color: #bfd3ff;
	display: inline-flex;
	font-size: .85rem;
	font-weight: 600;
	gap: 10px;
	margin-top: 22px;
	padding: 10px 18px
}
.case-badge i {
	color: #60a5fa
}
@media (max-width:850px) {
	.slide-content h3 {
		font-size: 1.6rem
	}
	.case-quote {
		margin-top: 26px;
		padding: 22px 22px 22px 24px
	}
	.case-quote blockquote {
		font-size: 1rem
	}
	.case-stat {
		flex: 1 1 100%
	}
}
.about-trust {
	border-top: none;
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	margin: 58px auto 0;
	max-width: 860px;
	padding-top: 0
}
.trust-chip {
	align-items: center;
	background: var(--white);
	border: 1px solid var(--border-color);
	border-radius: 16px;
	box-shadow: 0 14px 34px -28px rgba(15, 23, 42, .45);
	color: var(--dark);
	display: inline-flex;
	font-size: .88rem;
	font-weight: 750;
	gap: 10px;
	justify-content: center;
	min-height: 58px;
	padding: 13px 16px;
	transition: var(--transition);
	white-space: nowrap;
	width: 100%
}
.trust-chip i {
	color: var(--primary);
	flex-shrink: 0;
	font-size: .95rem;
	text-align: center;
	width: 18px
}
.trust-chip:hover {
	border-color: rgba(0, 82, 255, .24);
	box-shadow: 0 18px 38px -28px rgba(0, 82, 255, .35);
	transform: translateY(-3px)
}
@media (max-width:900px) {
	.about-trust {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		margin-top: 46px;
		max-width: 560px
	}
	.trust-chip {
		min-height: 62px
	}
}
@media (max-width:560px) {
	.about-trust {
		gap: 12px;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		margin-top: 42px;
		max-width: 100%
	}
	.trust-chip {
		border-radius: 16px;
		flex-direction: column;
		font-size: .82rem;
		gap: 7px;
		line-height: 1.25;
		min-height: 66px;
		padding: 13px 10px;
		text-align: center;
		white-space: normal
	}
	.trust-chip i {
		font-size: 1rem
	}
}
.mini-cta {
	align-items: center;
	border: 1px solid var(--border-color);
	border-radius: 22px;
	box-shadow: 0 18px 44px -34px rgba(15, 23, 42, .42);
	display: grid;
	gap: 28px;
	grid-template-columns: minmax(0, 1fr) auto;
	margin: 56px auto 0;
	max-width: 980px;
	padding: 26px 30px
}
.mini-cta-light {
	background: var(--white)
}
.mini-cta-white {
	background: radial-gradient(circle at 12% 20%, rgba(0, 82, 255, .045) 0, transparent 34%), var(--white)
}
.mini-cta-dark {
	background: hsla(0, 0%, 100%, .045);
	border-color: hsla(0, 0%, 100%, .09);
	box-shadow: 0 22px 60px -42px rgba(0, 0, 0, .85)
}
.mini-cta-content {
	min-width: 0
}
.mini-cta-kicker {
	align-items: center;
	color: var(--primary);
	display: inline-flex;
	font-size: .78rem;
	font-weight: 800;
	letter-spacing: .1em;
	margin-bottom: 9px;
	text-transform: uppercase
}
.mini-cta h3 {
	color: var(--dark);
	font-size: clamp(1.2rem, 2vw, 1.55rem);
	letter-spacing: -.025em;
	margin-bottom: 8px
}
.mini-cta p {
	color: var(--light-text);
	font-size: .96rem;
	line-height: 1.6;
	max-width: 620px
}
.mini-cta-action {
	align-items: flex-end;
	display: flex;
	flex-direction: column;
	gap: 9px;
	white-space: nowrap
}
.mini-cta-action .btn-sm {
	border-radius: 12px;
	padding: 13px 20px
}
.mini-cta-action .btn-sm i {
	font-size: .85rem;
	transition: transform .3s ease
}
.mini-cta-action .btn-sm:hover i {
	transform: translateX(3px)
}
.mini-cta-action span {
	color: var(--light-text);
	font-size: .82rem;
	font-weight: 700
}
.mini-cta-dark .mini-cta-kicker {
	color: #93c5fd
}
.mini-cta-dark h3 {
	color: var(--white)
}
.mini-cta-dark p {
	color: #cbd5e1
}
.mini-cta-dark .mini-cta-action span {
	color: #94a3b8
}
@media (max-width:820px) {
	.mini-cta {
		gap: 22px;
		grid-template-columns: 1fr;
		padding: 26px 22px;
		text-align: center
	}
	.mini-cta p {
		margin-left: auto;
		margin-right: auto
	}
	.mini-cta-action {
		align-items: center;
		white-space: normal
	}
	.mini-cta-action .btn-sm {
		max-width: 340px;
		width: 100%
	}
}
@media (max-width:520px) {
	.mini-cta {
		border-radius: 20px;
		margin-top: 42px;
		padding: 24px 18px
	}
	.mini-cta-kicker {
		font-size: .72rem;
		line-height: 1.35
	}
	.mini-cta h3 {
		font-size: 1.18rem
	}
	.mini-cta p {
		font-size: .92rem
	}
	.mini-cta-action .btn-sm {
		font-size: .86rem;
		padding: 13px 16px
	}
}
@media (max-width:768px) {
	.header {
		padding: 12px 0
	}
	.header .container {
		padding-left: 16px;
		padding-right: 16px
	}
	.header-inner {
		gap: 12px
	}
	.logo {
		font-size: clamp(1.08rem, 5vw, 1.28rem);
		line-height: 1;
		min-width: 0
	}
	.nav {
		flex-shrink: 0;
		gap: 0
	}
	.btn-lg {
		border-radius: 14px;
		font-size: .98rem;
		max-width: 340px;
		min-height: 56px;
		padding: 16px 22px;
		width: 100%
	}
}
@media (max-width:850px) {
	.browser-bar {
		gap: 10px;
		padding: 10px
	}
	.browser-address {
		border-radius: 12px;
		font-size: .78rem;
		justify-content: flex-start;
		max-width: none;
		min-width: 0;
		overflow: hidden;
		padding: 10px 12px;
		text-overflow: ellipsis;
		white-space: nowrap
	}
	.browser-action {
		flex: 0 0 auto
	}
	.browser-btn {
		border-radius: 12px;
		font-size: 0;
		gap: 0;
		height: 44px;
		padding: 0;
		width: 44px
	}
	.browser-btn i {
		font-size: 1rem
	}
	.visual-hints {
		background: #0f172a;
		border-top: 1px solid hsla(0, 0%, 100%, .06);
		flex-direction: row;
		flex-wrap: wrap;
		gap: 8px;
		justify-content: center;
		padding: 12px;
		position: static;
		width: auto
	}
	.slide-visual:hover .visual-hints {
		opacity: 1
	}
	.hint-badge-clear {
		font-size: .72rem;
		letter-spacing: .035em;
		padding: 7px 12px
	}
}
@media (max-width:560px) {
	.about-card {
		display: grid;
		gap: 12px;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		padding: 22px
	}
	.about-photo-wrap, .about-region {
		grid-column: 1/-1
	}
	.about-mini-badge {
		align-items: center;
		border-radius: 16px !important;
		box-shadow: 0 12px 26px -18px rgba(15, 23, 42, .35) !important;
		font-size: .78rem;
		justify-content: flex-start !important;
		line-height: 1.25;
		margin: 0 !important;
		max-width: none !important;
		min-height: 64px;
		padding: 12px !important;
		position: static !important;
		width: 100% !important
	}
	.about-badge-experience, .about-badge-local {
		bottom: auto !important;
		left: auto !important;
		right: auto !important;
		top: auto !important
	}
	.about-mini-badge i {
		font-size: 1rem
	}
	.about-mini-badge strong {
		display: inline;
		margin-right: 3px
	}
}
@media (max-width:370px) {
	.about-card {
		grid-template-columns: 1fr
	}
	.about-mini-badge, .about-photo-wrap, .about-region {
		grid-column: 1/-1
	}
}
@media (max-width:850px) {
	.browser-bar {
		align-items: center;
		gap: 12px;
		padding: 14px 16px
	}
	.browser-address {
		border-radius: 18px;
		flex: 1 1 auto;
		font-size: .95rem;
		height: 58px;
		justify-content: flex-start;
		min-width: 0;
		overflow: hidden;
		padding: 0 18px;
		text-overflow: ellipsis;
		white-space: nowrap
	}
	.browser-address i {
		flex: 0 0 auto;
		font-size: .9rem
	}
	.browser-action {
		flex: 0 0 auto
	}
	.browser-action, .browser-btn {
		align-items: center;
		display: flex;
		justify-content: center
	}
	.browser-btn {
		border-radius: 18px;
		font-size: 0;
		gap: 0;
		height: 58px;
		line-height: 1;
		min-height: 58px;
		min-width: 58px;
		padding: 0 !important;
		width: 58px
	}
	.browser-btn i {
		display: block;
		font-size: 1.35rem;
		height: 1em;
		line-height: 1;
		margin: 0;
		padding: 0;
		text-align: center;
		transform: none;
		width: 1em
	}
}
@media (max-width:560px) {
	.about-photo-wrap {
		overflow: visible;
		position: relative
	}
	.about-mini-badge {
		align-items: center;
		backdrop-filter: blur(8px);
		-webkit-backdrop-filter: blur(8px);
		background: hsla(0, 0%, 100%, .94);
		border-radius: 18px !important;
		bottom: 16px !important;
		box-shadow: 0 16px 28px -18px rgba(15, 23, 42, .28) !important;
		display: flex;
		gap: 10px;
		justify-content: flex-start;
		margin: 0 !important;
		max-width: 240px !important;
		min-height: 76px;
		overflow: hidden;
		padding: 14px !important;
		position: absolute !important;
		top: auto !important;
		width: calc(50% - 18px) !important;
		z-index: 3
	}
	.about-badge-experience {
		left: 14px !important;
		right: auto !important
	}
	.about-badge-local {
		left: auto !important;
		right: 14px !important
	}
	.about-mini-badge .fa-regular, .about-mini-badge .fa-solid, .about-mini-badge i {
		flex: 0 0 auto;
		font-size: 1.05rem;
		line-height: 1
	}
	.about-mini-badge div, .about-mini-badge p, .about-mini-badge span, .about-mini-badge strong {
		hyphens: auto;
		min-width: 0;
		overflow-wrap: break-word;
		word-break: normal
	}
	.about-mini-badge strong {
		display: block;
		font-size: .97rem;
		line-height: 1.15;
		margin-bottom: 2px
	}
	.about-mini-badge p, .about-mini-badge span {
		display: block;
		font-size: .9rem;
		line-height: 1.15
	}
	.about-mini-badge {
		font-size: .95rem;
		line-height: 1.15
	}
}
@media (max-width:420px) {
	.about-mini-badge {
		border-radius: 16px !important;
		min-height: 70px;
		padding: 12px !important;
		width: calc(50% - 16px) !important
	}
	.about-badge-experience {
		bottom: 12px !important;
		left: 12px !important
	}
	.about-badge-local {
		bottom: 12px !important;
		right: 12px !important
	}
	.about-mini-badge strong {
		font-size: .9rem
	}
	.about-mini-badge, .about-mini-badge p, .about-mini-badge span {
		font-size: .84rem
	}
}
@media (max-width:360px) {
	.about-card {
		display: grid;
		gap: 12px;
		grid-template-columns: 1fr
	}
	.about-photo-wrap, .about-region {
		grid-column: 1/-1
	}
	.about-mini-badge {
		bottom: auto !important;
		left: auto !important;
		max-width: none !important;
		min-height: 64px;
		position: static !important;
		right: auto !important;
		width: 100% !important
	}
}
@media (max-width:560px) {
	.about-card {
		display: grid;
		gap: 0 12px;
		grid-template-columns: 1fr 1fr;
		overflow: hidden;
		padding: 24px
	}
	.about-photo-wrap {
		border-radius: 24px;
		grid-column: 1/-1;
		grid-row: 1;
		margin: 0;
		overflow: hidden;
		position: relative
	}
	.about-photo-wrap img {
		border-radius: 24px;
		display: block;
		height: auto;
		width: 100%
	}
	.about-mini-badge {
		align-items: center;
		align-self: end;
		backdrop-filter: blur(10px);
		-webkit-backdrop-filter: blur(10px);
		background: hsla(0, 0%, 100%, .94);
		border-radius: 18px !important;
		bottom: auto !important;
		box-shadow: 0 16px 34px -18px rgba(15, 23, 42, .35) !important;
		display: flex;
		font-size: .88rem;
		gap: 10px;
		grid-row: 1;
		justify-content: flex-start;
		left: auto !important;
		line-height: 1.15;
		margin: 0 0 14px !important;
		max-width: none !important;
		min-height: 70px;
		overflow: hidden;
		padding: 12px !important;
		position: relative !important;
		right: auto !important;
		top: auto !important;
		width: 100% !important;
		z-index: 5
	}
	.about-badge-experience {
		grid-column: 1;
		justify-self: start;
		margin-left: 0 !important
	}
	.about-badge-local {
		grid-column: 2;
		justify-self: end;
		margin-right: 0 !important
	}
	.about-mini-badge i {
		flex: 0 0 22px;
		font-size: 1rem;
		line-height: 1;
		text-align: center;
		width: 22px
	}
	.about-mini-badge div, .about-mini-badge p, .about-mini-badge span, .about-mini-badge strong {
		hyphens: none;
		line-height: 1.15;
		max-width: 100%;
		min-width: 0;
		overflow-wrap: normal;
		word-break: normal
	}
	.about-mini-badge strong {
		display: block;
		font-size: .92rem;
		line-height: 1.15
	}
	.about-region {
		border-top: 1px solid rgba(15, 23, 42, .08);
		grid-column: 1/-1;
		grid-row: 2;
		margin-top: 28px;
		padding-top: 28px
	}
}
@media (max-width:410px) {
	.about-card {
		gap: 0 10px;
		padding: 20px
	}
	.about-mini-badge {
		border-radius: 16px !important;
		font-size: .8rem;
		gap: 8px;
		margin-bottom: 12px !important;
		min-height: 66px;
		padding: 10px !important
	}
	.about-mini-badge strong {
		font-size: .84rem
	}
	.about-mini-badge i {
		flex-basis: 20px;
		font-size: .95rem;
		width: 20px
	}
	.about-region {
		margin-top: 24px;
		padding-top: 24px
	}
}
@media (max-width:360px) {
	.about-card {
		gap: 10px;
		grid-template-columns: 1fr
	}
	.about-photo-wrap {
		grid-column: 1;
		grid-row: 1
	}
	.about-mini-badge {
		align-self: auto;
		grid-column: 1 !important;
		grid-row: auto;
		margin: 0 !important;
		width: 100% !important
	}
	.about-region {
		grid-column: 1;
		grid-row: auto;
		margin-top: 18px
	}
}
@media (max-width:560px) {
	.about-card {
		display: grid;
		gap: 14px;
		grid-template-columns: 1fr 1fr;
		overflow: hidden;
		padding: 24px
	}
	.about-photo-wrap {
		border-radius: 24px;
		grid-column: 1/-1;
		grid-row: auto;
		margin: 0;
		overflow: hidden;
		position: relative
	}
	.about-photo-wrap img {
		border-radius: 24px;
		display: block;
		height: auto;
		width: 100%
	}
	.about-mini-badge {
		align-items: center;
		background: #fff;
		border: 1px solid rgba(15, 23, 42, .08);
		border-radius: 18px !important;
		box-shadow: 0 14px 32px -22px rgba(15, 23, 42, .35) !important;
		display: flex;
		gap: 12px;
		grid-row: auto;
		inset: auto !important;
		justify-content: flex-start;
		line-height: 1.18;
		margin: 0 !important;
		max-width: none !important;
		min-height: 78px;
		overflow: hidden;
		padding: 14px !important;
		position: static !important;
		text-align: left;
		width: 100% !important;
		z-index: auto
	}
	.about-badge-experience {
		grid-column: 1
	}
	.about-badge-local {
		grid-column: 2
	}
	.about-mini-badge i {
		flex: 0 0 24px;
		font-size: 1.1rem;
		line-height: 1;
		text-align: center;
		width: 24px
	}
	.about-mini-badge div, .about-mini-badge p, .about-mini-badge span, .about-mini-badge strong {
		hyphens: auto;
		line-height: 1.18;
		max-width: 100%;
		min-width: 0;
		overflow-wrap: break-word;
		word-break: normal
	}
	.about-mini-badge strong {
		display: block;
		font-size: .95rem;
		line-height: 1.15
	}
	.about-mini-badge p, .about-mini-badge span {
		display: block;
		font-size: .86rem
	}
	.about-region {
		border-top: 1px solid rgba(15, 23, 42, .08);
		grid-column: 1/-1;
		margin-top: 16px;
		padding-top: 28px
	}
}
@media (max-width:390px) {
	.about-card {
		gap: 12px;
		grid-template-columns: 1fr;
		padding: 22px
	}
	.about-mini-badge, .about-photo-wrap, .about-region {
		grid-column: 1/-1
	}
	.about-mini-badge {
		min-height: 66px
	}
}
:focus-visible {
	border-radius: 4px;
	outline: 3px solid var(--primary);
	outline-offset: 3px
}
.bg-dark :focus-visible, .project-request-section :focus-visible {
	outline-color: #fff
}
:focus:not(:focus-visible) {
	outline: none
}
@media (prefers-reduced-motion:reduce) {
	html {
		scroll-behavior: auto
	}
	*, :after, :before {
		animation-duration: .01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: .01ms !important
	}
}
@media (max-width:390px) {
	.about-badge-local {
		display: none !important
	}
	.about-badge-experience {
		order: 2
	}
	.about-region {
		order: 1
	}
}
.nav-toggle {
	background: transparent;
	border: none;
	cursor: pointer;
	display: none;
	flex-direction: column;
	gap: 5px;
	height: 44px;
	justify-content: center;
	padding: 0;
	width: 44px;
	-webkit-tap-highlight-color: transparent
}
.nav-toggle-bar {
	background: var(--dark);
	border-radius: 2px;
	height: 2px;
	margin: 0 auto;
	transition: transform .3s ease, opacity .3s ease;
	width: 24px
}
.nav-toggle.is-active .nav-toggle-bar:first-child {
	transform: translateY(7px) rotate(45deg)
}
.nav-toggle.is-active .nav-toggle-bar:nth-child(2) {
	opacity: 0
}
.nav-toggle.is-active .nav-toggle-bar:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg)
}
.mobile-menu {
	inset: 0;
	position: fixed;
	visibility: hidden;
	z-index: 4000
}
.mobile-menu.is-open {
	visibility: visible
}
.mobile-menu-backdrop {
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	background: rgba(2, 6, 23, .6);
	cursor: pointer;
	inset: 0;
	opacity: 0;
	position: absolute;
	transition: opacity .3s ease
}
.mobile-menu.is-open .mobile-menu-backdrop {
	opacity: 1
}
.mobile-menu-panel {
	background: var(--white);
	bottom: 0;
	box-shadow: -20px 0 60px -20px rgba(0, 0, 0, .35);
	display: flex;
	flex-direction: column;
	overflow-y: auto;
	padding: 22px 24px calc(24px + env(safe-area-inset-bottom));
	position: absolute;
	right: 0;
	top: 0;
	transform: translateX(100%);
	transition: transform .32s cubic-bezier(.4, 0, .2, 1);
	width: min(88vw, 360px)
}
.mobile-menu.is-open .mobile-menu-panel {
	transform: translateX(0)
}
.mobile-menu-head {
	align-items: center;
	display: flex;
	justify-content: space-between;
	margin-bottom: 26px
}
.mobile-menu-close {
	align-items: center;
	background: var(--bg-light);
	border: none;
	border-radius: 12px;
	color: var(--dark);
	cursor: pointer;
	display: flex;
	font-size: 1.1rem;
	height: 44px;
	justify-content: center;
	width: 44px;
	-webkit-tap-highlight-color: transparent
}
.mobile-menu-links {
	display: flex;
	flex-direction: column;
	gap: 4px
}
.mobile-menu-links a {
	align-items: center;
	border-radius: 12px;
	color: var(--text);
	display: flex;
	font-size: 1.05rem;
	font-weight: 700;
	gap: 14px;
	min-height: 52px;
	padding: 14px;
	text-decoration: none;
	transition: background .2s ease, color .2s ease
}
.mobile-menu-links a:active, .mobile-menu-links a:hover {
	background: var(--bg-light);
	color: var(--primary)
}
.mobile-menu-links a i {
	color: var(--primary);
	font-size: 1rem;
	text-align: center;
	width: 22px
}
.mobile-menu-cta {
	margin-top: 22px;
	width: 100%
}
.mobile-menu-region {
	align-items: center;
	color: var(--light-text);
	display: flex;
	font-size: .9rem;
	font-weight: 600;
	gap: 10px;
	margin-top: auto;
	padding-top: 26px
}
.mobile-menu-region i {
	color: var(--primary)
}
.mobile-cta-bar {
	align-items: center;
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	background: hsla(0, 0%, 100%, .92);
	border-top: 1px solid var(--border-color);
	bottom: 0;
	box-shadow: 0 -8px 24px -12px rgba(15, 23, 42, .18);
	display: none;
	gap: 16px;
	justify-content: space-between;
	left: 0;
	padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
	position: fixed;
	right: 0;
	transform: translateY(120%);
	transition: transform .35s cubic-bezier(.4, 0, .2, 1);
	z-index: 1500
}
.mobile-cta-bar.is-visible {
	transform: translateY(0)
}
.mobile-cta-text {
	display: flex;
	flex-direction: column;
	line-height: 1.2;
	min-width: 0
}
.mobile-cta-text strong {
	color: var(--dark);
	font-size: .98rem;
	font-weight: 800
}
.mobile-cta-text span {
	color: var(--light-text);
	font-size: .8rem;
	font-weight: 600
}
.mobile-cta-btn {
	flex-shrink: 0;
	min-height: 46px;
	padding: 12px 22px;
	white-space: nowrap
}
:where(section[id]) {
	scroll-margin-top: 84px
}
@media (max-width:768px) {
	.nav {
		display: none
	}
	.mobile-cta-bar, .nav-toggle {
		display: flex
	}
}
.carousel-dots {
	align-items: center;
	display: none;
	gap: 6px;
	justify-content: center;
	margin-top: 26px
}
.carousel-dot {
	background: transparent;
	border: none;
	cursor: pointer;
	height: 28px;
	padding: 0;
	position: relative;
	width: 28px;
	-webkit-tap-highlight-color: transparent
}
.carousel-dot:before {
	background: rgba(148, 163, 184, .45);
	border-radius: 50px;
	content: "";
	height: 9px;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	transition: width .28s cubic-bezier(.4, 0, .2, 1), background .28s ease;
	width: 9px
}
.carousel-dot.is-active:before {
	background: var(--primary);
	width: 26px
}
@media (max-width:850px) {
	.portfolio-img-wrap {
		height: clamp(300px, 48vh, 440px);
		overflow: hidden;
		position: relative;
		-webkit-overflow-scrolling: auto
	}
	.portfolio-img-wrap:after {
		background: linear-gradient(0deg, rgba(15, 23, 42, .3), transparent);
		bottom: 0;
		content: "";
		height: 72px;
		left: 0;
		pointer-events: none;
		position: absolute;
		right: 0
	}
	.carousel-btn, .visual-hints .hint-scroll {
		display: none
	}
	.carousel-dots {
		display: flex
	}
}
.swipe-chevron {
	align-items: center;
	background: transparent;
	border: none;
	color: #fff;
	cursor: pointer;
	display: none;
	font-size: .8rem;
	height: 44px;
	justify-content: center;
	padding: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 44px;
	z-index: 2;
	-webkit-tap-highlight-color: transparent
}
.swipe-chevron:before {
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	background: rgba(15, 23, 42, .42);
	border-radius: 50%;
	box-shadow: 0 2px 10px rgba(0, 0, 0, .22);
	content: "";
	inset: 5px;
	opacity: .7;
	position: absolute;
	transition: opacity .2s ease
}
.swipe-chevron:active:before {
	opacity: 1
}
.swipe-chevron.prev {
	left: 4px
}
.swipe-chevron.next {
	right: 4px
}
.swipe-chevron i {
	position: relative;
	z-index: 1
}
@keyframes swipe-hint-prev {
	0%, to {
		transform: translateY(-50%)
	}
	45% {
		transform: translate(-4px, -50%)
	}
}
@keyframes swipe-hint-next {
	0%, to {
		transform: translateY(-50%)
	}
	45% {
		transform: translate(4px, -50%)
	}
}
@media (max-width:850px) {
	.swipe-chevron {
		display: inline-flex
	}
	.carousel-wrapper.show-swipe-hint .swipe-chevron.prev {
		animation: swipe-hint-prev .85s ease-in-out 3
	}
	.carousel-wrapper.show-swipe-hint .swipe-chevron.next {
		animation: swipe-hint-next .85s ease-in-out 3
	}
}
@media (prefers-reduced-motion:reduce) {
	.carousel-wrapper.show-swipe-hint .swipe-chevron.next, .carousel-wrapper.show-swipe-hint .swipe-chevron.prev {
		animation: none
	}
}
html {
	-webkit-text-size-adjust: 100%;
	text-size-adjust: 100%
}
@media (max-width:600px) {
	.section-padding {
		padding: 64px 0
	}
	.hero {
		padding: 64px 0 72px
	}
	#loesungen .center-title, #referenz .center-title {
		margin-bottom: 44px
	}
	.section-title p {
		font-size: 1.05rem;
		margin-top: 16px
	}
	.hero h1 {
		line-height: 1.12;
		margin-bottom: 18px
	}
	.hero-sub {
		font-size: 1.08rem;
		margin-bottom: 28px
	}
	.trust-badge {
		margin-bottom: 22px
	}
	.mini-cta {
		margin-top: 40px
	}
	:where(section[id]) {
		scroll-margin-top: 72px
	}
}
@media (max-width:380px) {
	.section-padding {
		padding: 56px 0
	}
	.hero {
		padding: 56px 0 64px
	}
	.container {
		padding: 0 20px
	}
	#loesungen .center-title, #referenz .center-title {
		margin-bottom: 36px
	}
	.hero-sub {
		font-size: 1.02rem
	}
	.section-title p {
		font-size: 1rem
	}
}

/* ===== Finale CTA-Sektion (zeigt auf den Rechner) ===== */
.final-cta-action {
	margin-top: 34px
}
.project-request-note a {
	color: #fff;
	text-decoration: underline;
	text-underline-offset: 3px
}

/* Finale-Sektion kompakter (Formular ist weg, sonst leeres Navy unten) */
@media (min-width: 993px) {
	.project-request-section {
		padding: 96px 0
	}
}
.project-request-section .project-request-heading {
	margin-bottom: 0
}