@import url('https://fonts.googleapis.com/css2?family=Gilda+Display&display=swap');

.dp-hero {
    --dp-bg: #be514a;
    --dp-fg: #fff;
    --dp-hole-size: min(45vw, 45svh);
    position: relative;
    background: var(--dp-bg);
    color: var(--dp-fg);
    height: 360vh;
    overflow: clip;
}

.dp-hero__stage {
    position: absolute;
    inset-inline: 0;
    top: 0;
    height: 100svh;
    overflow: hidden;
    isolation: isolate;
}

.dp-hero__stage.is-fixed {
    position: fixed;
    left: 0;
    width: 100vw;
    top: 0;
    z-index: 30;
}

.dp-hero__stage.is-after {
    position: absolute;
    inset-inline: 0;
    top: calc(100% - 100svh);
}

.dp-hero__video-wrap {
    position: absolute;
    inset: 0;
    z-index: 2;
}

.dp-hero__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.dp-hero__overlay {
    position: absolute;
    inset: 0;
    z-index: 4;
    pointer-events: none;
}

.dp-hero__hole {
    position: absolute;
    left: 50%;
    top: 50%;
    width: var(--dp-hole-size);
    height: var(--dp-hole-size);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    box-shadow: 0 0 0 200vmax var(--dp-bg);
    will-change: width, height;
}

.dp-hero__title {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    margin: 0;
    color: #fff;
    text-align: center;
    font-family: "Gilda Display", Georgia, "Times New Roman", serif;
    font-size: min(260px, 21vw);
    font-weight: 400;
    line-height: 0.92;
    letter-spacing: 0.01em;
    mix-blend-mode: exclusion;
    will-change: transform, opacity;
    white-space: nowrap;
}

@media (max-width: 1024px) {
    .dp-hero__title {
        font-size: clamp(70px, 18vw, 180px);
    }
}

@media (max-width: 767px) {
    .dp-hero {
        height: 320vh;
    }

    .dp-hero__title {
        font-size: clamp(38px, 13vw, 76px);
    }
}

@supports not (height: 100svh) {
    .dp-hero__stage {
        height: 100vh;
    }
}
