.banner {
    position: relative;
    background: linear-gradient(120deg, rgb(58, 123, 255), rgb(136, 54, 255));
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: clamp(420px, 70vh, 640px);
    padding: 96px 0;
    overflow: hidden;
}
.banner::after {
    content: "";
    position: absolute;
    inset: -20%;
    background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.35), transparent 55%),
        radial-gradient(circle at bottom right, rgba(0, 0, 0, 0.25), transparent 60%);
    pointer-events: none;
}
@media (prefers-color-scheme: dark) {
    .banner {
        background: linear-gradient(120deg, #1b55d6, #4300c6);
    }
    .banner::after {
        background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.18), transparent 55%),
            radial-gradient(circle at bottom right, rgba(0, 0, 0, 0.35), transparent 60%);
    }
}
.intro {
    position: relative;
    z-index: 1;
    display: flex;
    gap: 56px;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    text-align: left;
}
.intro-media img {
    width: 140px;
    height: 140px;
    border-radius: 50%;
    border: 4px solid rgba(255, 255, 255, 0.4);
    box-shadow: 0 18px 48px -24px rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(6px);
}
@media (prefers-color-scheme: dark) {
    .intro-media img {
        border-color: rgba(255, 255, 255, 0.18);
        box-shadow: 0 18px 48px -24px rgba(0, 0, 0, 0.9);
    }
}
.intro-copy {
    max-width: 520px;
}
.intro-copy h1 {
    font-size: clamp(36px, 5vw, 54px);
    margin: 8px 0 12px;
}
.intro-copy p {
    margin: 12px 0;
}
.button.filled {
    color: var(--accent-color);
    background-color: var(--text-color);
}
.button.ghost {
    background-color: transparent;
    border: 1px solid rgba(255, 255, 255, 0.35);
    color: var(--heading-text-color);
}
@media (prefers-color-scheme: light) {
    .button.ghost {
        border-color: rgba(0, 0, 0, 0.1);
        color: var(--text-color);
    }
}
@media (max-width: 720px) {
    .banner {
        padding: 72px 0;
    }
    .intro {
        gap: 32px;
    }
    .cta-buttons {
        justify-content: flex-start;
    }
}
.contact-panel {
    display: flex;
    justify-content: center;
    text-align: left;
    padding: 16px 0;
}
.contact-form {
    padding: 32px;
    border-radius: var(--border-radius);
    background: var(--grouped-secondary-bg-color);
    box-shadow: 0 30px 60px -50px rgba(0, 0, 0, 0.8);
    display: grid;
    gap: 16px;
    max-width: 520px;
    width: 100%;
}
.contact-form input,
.contact-form textarea {
    width: 100%;
}
@media (prefers-color-scheme: light) {
    .contact-form {
        box-shadow: 0 30px 60px -45px rgba(50, 30, 90, 0.35);
    }
}
.contact-form .g-recaptcha {
    margin: 8px 0 0;
}
.contact-form .button {
    justify-self: start;
}
@media (max-width: 600px) {
    .contact-form {
        padding: 24px;
    }
}
