#stateof-page {
    --stateof-blue: #0b4f8a;
    --stateof-navy: #071525;
    --stateof-ink: #dcecff;
    --stateof-cyan: #2fd3ff;
    --stateof-magenta: #b45cff;
    --stateof-orange: #f28c12;
    --stateof-panel: rgba(255,255,255,.08);
    --stateof-rounded-hex: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 86.602'%3E%3Cpath fill='white' d='M31 3H69Q74.2 3 76.8 7.5L96.2 39Q98.8 43.301 96.2 47.6L76.8 79.1Q74.2 83.602 69 83.602H31Q25.8 83.602 23.2 79.1L3.8 47.6Q1.2 43.301 3.8 39L23.2 7.5Q25.8 3 31 3Z'/%3E%3C/svg%3E");
    color: #152033;
}

#stateof-page .stateof-hero {
    position: relative;
    overflow: hidden;
    border-radius: 1rem;
    background:
        radial-gradient(circle at 75% 20%, rgba(47,211,255,.32), transparent 28rem),
        radial-gradient(circle at 18% 84%, rgba(180,92,255,.28), transparent 26rem),
        linear-gradient(135deg, #071525 0%, #0b315d 52%, #13092f 100%);
    min-height: clamp(520px, 58vw, 760px);
    isolation: isolate;
}

#stateof-page .stateof-hero::before,
#stateof-page .stateof-hero::after {
    content: "";
    position: absolute;
    -webkit-mask: var(--stateof-rounded-hex) center / 100% 100% no-repeat;
    mask: var(--stateof-rounded-hex) center / 100% 100% no-repeat;
    pointer-events: none;
}

#stateof-page .stateof-hero::before {
    width: min(58vw, 760px);
    aspect-ratio: 1.1547;
    right: -9%;
    top: 5%;
    background: linear-gradient(135deg, rgba(47,211,255,.26), rgba(255,255,255,.05));
    border: 1px solid rgba(255,255,255,.22);
    transform: rotate(10deg);
    z-index: -1;
}

#stateof-page .stateof-hero::after {
    width: min(42vw, 520px);
    aspect-ratio: 1.1547;
    left: -10%;
    bottom: -18%;
    background: linear-gradient(135deg, rgba(242,140,18,.28), rgba(180,92,255,.18));
    transform: rotate(-14deg);
    z-index: -1;
}

#stateof-page .stateof-hero-grid {
    position: absolute;
    inset: 0;
    opacity: .22;
    background-image:
        linear-gradient(30deg, rgba(255,255,255,.18) 12%, transparent 12.5%, transparent 87%, rgba(255,255,255,.18) 87.5%, rgba(255,255,255,.18)),
        linear-gradient(150deg, rgba(255,255,255,.18) 12%, transparent 12.5%, transparent 87%, rgba(255,255,255,.18) 87.5%, rgba(255,255,255,.18)),
        linear-gradient(30deg, rgba(255,255,255,.18) 12%, transparent 12.5%, transparent 87%, rgba(255,255,255,.18) 87.5%, rgba(255,255,255,.18)),
        linear-gradient(150deg, rgba(255,255,255,.18) 12%, transparent 12.5%, transparent 87%, rgba(255,255,255,.18) 87.5%, rgba(255,255,255,.18));
    background-size: 96px 168px;
    background-position: 0 0, 0 0, 48px 84px, 48px 84px;
    pointer-events: none;
}

#stateof-page .stateof-hero-content {
    position: relative;
    z-index: 1;
    color: #fff;
    max-width: 760px;
}

#stateof-page .stateof-kicker {
    display: inline-flex;
    gap: .6rem;
    align-items: center;
    padding: .45rem .85rem;
    border: 1px solid rgba(255,255,255,.25);
    border-radius: 999px;
    background: rgba(255,255,255,.09);
    color: var(--stateof-ink);
    text-transform: uppercase;
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .08em;
}

#stateof-page .stateof-mark {
    display: inline-grid;
    place-items: center;
    width: 6rem;
    aspect-ratio: 1.154700538;
    -webkit-mask: var(--stateof-rounded-hex) center / 100% 100% no-repeat;
    mask: var(--stateof-rounded-hex) center / 100% 100% no-repeat;
    background: linear-gradient(135deg, var(--stateof-cyan), var(--stateof-magenta));
    color: #fff;
    font-weight: 900;
    box-shadow: 0 1rem 3rem rgba(47,211,255,.22);
}

#stateof-page .stateof-hero h1 {
    font-size: clamp(3rem, 8vw, 7.5rem);
    line-height: .86;
    letter-spacing: 0;
}

#stateof-page .stateof-hero .lead {
    color: rgba(255,255,255,.8);
    max-width: 58rem;
}

#stateof-page .stateof-fact {
    background: var(--stateof-panel);
    border: 1px solid rgba(255,255,255,.16);
    color: #fff;
    backdrop-filter: blur(12px);
}

#stateof-page .stateof-fact strong {
    color: var(--stateof-cyan);
    display: block;
    font-size: 1.6rem;
}

#stateof-page .stateof-section-dark {
    border-radius: 1rem;
    background:
        radial-gradient(circle at top right, rgba(47,211,255,.22), transparent 24rem),
        linear-gradient(135deg, #081827, #111a35);
    color: #fff;
}

#stateof-page .stateof-hex-card {
    display: grid;
    place-items: center;
    width: 100%;
    aspect-ratio: 1.154700538;
    min-height: 0;
    padding: 2rem;
    text-decoration: none;
    color: #fff;
    -webkit-mask: var(--stateof-rounded-hex) center / 100% 100% no-repeat;
    mask: var(--stateof-rounded-hex) center / 100% 100% no-repeat;
    background: linear-gradient(135deg, var(--stateof-blue), #122246);
    transition: transform .18s ease, filter .18s ease;
}

#stateof-page .stateof-hex-card:hover {
    color: #fff;
    transform: translateY(-4px) scale(1.015);
    filter: saturate(1.18);
}

#stateof-page .stateof-hex-card span {
    display: block;
    text-align: center;
}

#stateof-page .stateof-hex-card .h3 {
    font-weight: 800;
}

#stateof-page .stateof-hex-blue { background: linear-gradient(135deg, #0d6efd, #061d54); }
#stateof-page .stateof-hex-cyan { background: linear-gradient(135deg, #08bcf4, #045167); }
#stateof-page .stateof-hex-purple { background: linear-gradient(135deg, #8e5cff, #2d1166); }
#stateof-page .stateof-hex-orange { background: linear-gradient(135deg, #f28c12, #7b3300); }
#stateof-page .stateof-hex-green { background: linear-gradient(135deg, #1ba784, #063e34); }
#stateof-page .stateof-hex-pink { background: linear-gradient(135deg, #d344b8, #54104b); }
#stateof-page .stateof-hex-dark { background: linear-gradient(135deg, #38485f, #0a1322); }

#stateof-page .stateof-step {
    border-top: 1px solid rgba(21,32,51,.16);
}

@media (max-width: 767.98px) {
    #stateof-page .stateof-hero {
        min-height: auto;
        border-radius: .75rem;
    }

    #stateof-page .stateof-hex-card {
        aspect-ratio: 1.154700538;
        padding: 1.25rem;
    }
}
