/* =============================================================================
   Block: Hero
   CUBE CSS: Homepage hero — photo, vertical name, and opening statement.
   ============================================================================= */

section.content-wrapper {
    padding: 1vmax 0 3vmax 0;
    display: grid;
    grid-template-columns: 0.1fr 0.7fr min-content 1fr 0.3fr;
}

.content-wrapper #myFace {
    grid-column: 2/3;
    border-radius: 50%;
    align-self: center;
}

.content-wrapper #myName {
    grid-column: 3/4;
    writing-mode: vertical-lr;
    font-size: var(--text-3xl);
    font-family: var(--font-sans);
    text-align: center;
    margin-left: -50px;
}

.content-wrapper .openingStatement {
    grid-column: 4/6;
    align-self: center;
    padding-left: 30px;
}

.openingStatement h1,
.openingStatement #jsDarkArts {
    display: inline-block;
    color: var(--color-text);
    font-family: var(--font-sans);
    font-size: var(--text-hero);
    position: relative;
    margin: 0;
}

/* Animated gradient text effect */
.openingStatement h1::after {
    content: attr(data-shadow);
    position: absolute;
    top: 0.06em;
    left: 0.06em;
    z-index: -1;
    text-shadow: none;
    background-image: linear-gradient(350deg, transparent 15%, var(--color-accent) 45%, var(--color-accent) 55%, transparent 0);
    background-size: 1.05em 0.05em;
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: shad-anim 22s linear infinite;
    animation-direction: reverse;
}

.openingStatement #jsDarkArts {
    display: inline;
    text-shadow: -0.06em -0.06em var(--color-text);
    background-image: linear-gradient(350deg, transparent 15%, var(--color-accent) 45%, var(--color-accent) 55%, transparent 0);
    background-size: 1.05em 0.05em;
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: shad-anim 22s linear infinite;
    animation-direction: reverse;
}

@keyframes shad-anim {
    0%   { background-position: 0 0; }
    100% { background-position: 100% -100%; }
}

.openingStatement * {
    font-size: var(--text-hero);
}

.openingStatement p:last-child {
    margin-bottom: 0;
}

/* -----------------------------------------------------------------------------
   Mobile
   ----------------------------------------------------------------------------- */
@media (max-width: 768px) {
    section.content-wrapper {
        grid-template-columns: unset;
        grid-template-areas:
            "myFace myName"
            "openingStatement openingStatement";
        row-gap: 25px;
        column-gap: 15px;
    }

    .content-wrapper #myFace {
        grid-area: myFace;
    }

    .content-wrapper #myName {
        writing-mode: initial;
        text-align: left;
        word-spacing: 100vw;
        margin-left: unset;
        margin-top: 10px;
        grid-area: myName;
    }

    .content-wrapper .openingStatement {
        padding-left: 0;
        grid-area: openingStatement;
    }
}
