html, body {
    color: var(--font-base-color);
    min-height: 100vh;
    font-weight: 500;
}

.wrapper {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    padding: 0 6.944vw;
}

.header {
    height: 8vw;
    display: flex;
    align-items: center;
    justify-content: start;
}

.header-container {
    gap: var(--gap-16);
    display: flex;
    align-items: center;
    justify-content: start;
}

.header-logo {
    max-width: 100%;
    height: auto;
    object-fit: contain;
    display: block;
}

.logo{
    width: 3.472vw;
    height: 3.472vw;
    object-fit: contain;
    display: block;
}

.header-title {
    font-size: var(--font-24);
    font-weight: 500;
}

.hero {
    margin-top: 2.5vw;
    display: flex;
    position: relative;
    margin-bottom: 0;
    align-items: stretch;
}

.hero-left {
    position: relative;
    flex: 0 0 32.639vw;
    display: flex;
    flex-direction: column;
}

h1 {
    font-size: var(--font-40);
    font-weight: 500;
    margin-top: 0;
    margin-bottom: var(--gap-8);
}

.hero-subtitle {
    font-size: var(--font-20);
    font-weight: 400;
}

.hero-icon img {
    vertical-align: middle;
    width: 4.306vw;
    height: 4.306vw;
    object-fit: contain;
}

.hero-button {
    margin-top: var(--gap-32);
    background: var(--font-base-color);
    color: white;
    border-radius: var(--border-radius-4);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 4.931vw;
    height: 4.931vw;
    font-size: var(--font-20);
    transition: all 0.2s ease-in-out;
    max-width: 17.639vw;
}

.hero-developed {
    font-size: var(--font-10);
    position: absolute;
    bottom: 0;
    left: 0;
    color: var(--color-muted-text);
}

.hero-grid {
    flex: 1 1 auto;
    display: grid;
    grid-template-columns: repeat(4, 11vw); 
    grid-template-rows: 7.5vw 10.5vw 13.5vw;
    gap: 0.56vw; 
    justify-content: flex-end;
    align-content: flex-end;
    transform-origin: bottom right;
    transition: transform 0.16s ease-out, all 0.16s ease-out;
    will-change: transform;
}

.hero-grid img {
    max-width: 100%;
    height: auto;
    object-fit: contain;
    display: block;
}

.block-1-3 img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 0.9vw;
}

.block-4-3 img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 0.9vw;
}

.block-icon {
    object-fit: contain;
    display: block;
}

.block-icon--top-right {
    position: absolute;
    top: var(--gap-8);
    right: var(--gap-8);
    width: var(--gap-24);
    height: var(--gap-24);
}

.block-icon--top-center {
    position: absolute;
    top: -3vw;
    left: 50%;
    transform: translateX(-50%);
    width: 5.417vw;
    height: 5.417vw;
}

.block-icon--2-2 {
    width: 1.736vw;
    height: 1.736vw;
}

.block-text {
    margin-top: auto;
    margin-bottom: var(--gap-12);
    font-size: var(--font-14);
    width: 9.5vw;
}

.block-text--2-2 {
    font-size: var(--font-20);
    margin: 0;
    width: 23.403vw;
}

.block-text--3-2 {
    margin-bottom: var(--gap-16);
    margin-left: var(--gap-12);
    justify-self: start;
}

.block-text--4-1 {
    margin-top: auto;
    margin-bottom: 0;
    margin-left: 0;
    text-align: center;
    width: auto;
}

.block-text--4-2 {
    margin-bottom: var(--gap-12);
}

.block {
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.9vw;
    width: 11vw;
    background: #4b44cc;
    font-size: var(--font-16);
}

.block-1-3 {
    grid-column: 1;
    grid-row: 3;
    background: none;
}

.block-2-1 {
    grid-column: 2;
    grid-row: 2;
    background: none;
    margin-top: 5vw;
    margin-left: 2.5vw;
}

.block-2-2 {
    margin-top: var(--gap-16);
    grid-column: 2;
    grid-row: 3;
    height: 4.2vw;
    width: 20vw;
    background: var(--font-base-color);
    padding: 0 var(--gap-16);
    color: white;
    gap: var(--gap-16);
    font-size: var(--font-20);
}

.block-2-3 {
    grid-column: 2;
    grid-row: 3;
    height: 7.5vw;
    margin-top: auto;
    background: #D2D8FB;
    flex-direction: column;
    position: relative;
}

.block-3-2 {
    grid-column: 3;
    grid-row: 2;
    height: 10.5vw;
    background: none;
    border: 0.139vw solid #A9DAEE;
    color: var(--font-base-color);
    flex-direction: column;
    position: relative;
}

.block-3-3 {
    margin-top: auto;
    grid-column: 3;
    grid-row: 3;
    height: 13.5vw;
    background: #D2D8FB;
}

.block-4-1 {
    grid-column: 4;
    grid-row: 1;
    flex-direction: column;
    background: var(--background);
    align-items: center;
    justify-content: flex-start;
    padding: var(--gap-16) 0;
    position: relative;
}

.block-4-2 {
    grid-column: 4;
    grid-row: 2;
    height: 7.5vw;
    background: #D2D8FB;
    flex-direction: column;
    position: relative;
}

.block-4-3 {
    background: none;
    grid-column: 4;
    grid-row: 3;
    height: 16vw;
    margin-top: -2.8vw;
}
