body {
    font-family: "PT Sans", sans-serif;
    color: #0d0d0a !important;
	font-weight: 500;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: "IBM Plex Sans", sans-serif;
	font-weight: 700;
    line-height: 1;
}

h1, .h1 {
    font-size: 6em;
	font-weight: bolder;
}
h2, .h2 {
	font-size: 4.5em;
}

.lead {
    font-weight: normal;
}

.jumbotron {
    position: relative;
    background: white;
    padding-top: 8em;
    padding-bottom: calc(5em + 500px);
	overflow-x: clip;
}
    .jumbotron .wrapper {
        position: relative;
        z-index: 1;
    }

.premiere {
	position: absolute;
	height: 500px;
	left: -15px;
	transform: rotate(-2.5deg);
	margin-top: 2em;
}


.title-block {
	margin-bottom: 5em;
}

.magic-overlay {
    position: absolute;
    inset: 0;
    z-index: 0;
    margin: auto;
    transform: translate3d(0,0,0) rotate(0) skewX(0) skewY(0) scaleX(1) scaleY(1); /* use GPU */
    filter: blur(64px);
    overflow: clip;
}
    .magic {
        position: absolute;
        inset: 0;
        z-index: 0;
        background-image: linear-gradient(hsl(50deg, 83%, 56%), #ffffff1a);
        transition: clip-path 3.5s ease-in-out;
        clip-path: polygon(80% 43%, 97% 92%, 1% 59%, 64% 68%, 75% 41%, 10% 28%, 67% 45%, 35% 79%, 48% 65%, 72% 28%, 20% 32%, 52% 90%, 64% 70%, 10% 60%, 13% 11%, 33% 44%);
		transform: scale(1.2);
    }
	
.jumbotron .contacts {
	margin-top: 4em;
}
.contact-icons {
    display: inline;
}
	.contact-icons > a, .contacts > a {
		color: black;
		text-decoration: none !important;
	}
	.bi.bi-telephone {
		transform: scale(0.94);
	}
.contact {
    font-size: 1.5em;
    font-weight: 500;
    margin-bottom: 1em;
}
.contacts .contact-icons a {
    padding-left: 0.15em;
    padding-right: 0.15em;
}

footer {
    margin-top: 2em;
    padding-top: 2em;
    padding-bottom: 2em;
    border-top: 1px solid #e9e9e9;
    position: relative;
    opacity: 0.8;
    overflow: clip;
}
    footer > .container {
        position: relative;
        z-index: 1;
    }

.justify-content-center {
    display: flex;
}

.title {
	width: 100%;
	text-align: center;
	margin-bottom: 1em;
}

.examples {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2em 1em;
}
	.example img {
		max-width: 100%;
		height: auto;
		aspect-ratio: 1/1;
	}
	.example-caption {
		padding: 0.8em 1em 1em 1em;
	}
	.example-title {
		font-size: 225%;
		font-weight: 800;
		line-height: 1;
		margin-bottom: 0.25em;
	}
	.example-description {
		font-size: 115%;
	}

@media screen and (max-width: 1500px) {
	.examples {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media screen and (max-width: 992px) {
    h1, .h1 {
        font-size: 5.5em;
    }
    h2, .h2 {
        font-size: 4em;
    }
	.example-title {
		font-size: 185%;
	}
}

@media screen and (max-width: 768px) {
    h1, .h1 {
        font-size: 4.3em;
    }
    h2, .h2 {
        font-size: 3.5em;
    }
    .title-block {
        margin-bottom: 2em;
    }
	.examples {
		grid-template-columns: 1fr;
	}
	.example-description {
		line-height: 1.3;
	}
}

@media screen and (max-width: 576px) {
    h1, .h1 {
        font-size: 14vw;
    }
    h2, .h2 {
        font-size: 11vw;
    }
	.jumbotron {
		padding-bottom: calc(5em + 300px);
	}
	.premiere {
		height: 300px;
	}
	.example-title {
		font-size: 200%;
	}
	.example-description {
		font-size: 110%;
	}
}


.portfolio .card {
    border-radius: 0;
    box-shadow: none !important;
    border: none;
}
    .portfolio .card-body {
        padding: 0;
        text-align: center;
    }
    .portfolio .card img {
        border-radius: 0.3em;
    }
    .portfolio .card-title {
        font-weight: 500;
        font-size: 1em;
        margin-top: 0.3em;
    }

.back {
    position: fixed;
    top: 2em;
    left: 2em;
    border-bottom: 1px solid #e2e3e4;
    color: currentColor !important;
}
    .back:hover {
        text-decoration: none;
        border-color: #b2b3b4;
    }