.banner {
    position: relative;
    display: grid;
    min-height: min(720px, calc(100dvh - 76px));
    place-items: center;
    margin-bottom: 64px;
    overflow: hidden;
    background-color: var(--bg-base);
    background-image: radial-gradient(var(--bg-dot) 2.5px, transparent 2.5px);
    background-size: 22px 22px;
}



.banner-content {
    position: relative;
    z-index: 1;
    display: grid;
    justify-items: center;
    gap: 22px;
    width: min(calc(100% - 32px), 940px);
    padding: 48px 20px;
    text-align: center;
}

.banner-logo {
    width: clamp(96px, 13vw, 168px);
}

.banner-logo svg {
    display: block;
    width: 100%;
    height: auto;
}

.banner-kicker {
    margin: 0;
    padding: 8px 12px;
    border: 0;
    border-radius: 8px;
    background: var(--py-yellow);
    box-shadow: 0 var(--brick-depth) 0 color-mix(in srgb, var(--py-yellow) 68%, #000);
    font-family: var(--font-pixel);
    font-size: 0.7rem;
}

/* Banner-reference title: per-letter colors sampled from the banner (P=red
   Y=yellow C=blue O=cream N=purple / C=purple H=blue I=yellow N=red A=cream),
   "2026" beveled gray. Black 8-direction pixel outline per Frost's final call
   (an outline-free variant was tried and rejected). */
.banner-title {
    display: grid;
    justify-items: center;
    gap: 0.1em;
    margin: 0;
    font-family: var(--font-pixel);
    font-weight: 400;
    font-synthesis: none;
    font-size: clamp(1.8rem, 6vw, 4.4rem);
    line-height: 1.3;
}

.banner-title-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.06em;
}

/* Black pixel outline restored per Frost (2026-07-02) — per-letter banner
   colors stay; 8-direction ink outline + soft drop. */
.banner-title .lt {
    text-shadow:
        3px 0 0 var(--ink), -3px 0 0 var(--ink),
        0 3px 0 var(--ink), 0 -3px 0 var(--ink),
        3px 3px 0 var(--ink), -3px 3px 0 var(--ink),
        3px -3px 0 var(--ink), -3px -3px 0 var(--ink),
        7px 8px 0 rgba(26, 26, 26, 0.25);
}

.banner-title .lt-gap { width: 0.5em; }
.banner-title .lt-red { color: var(--py-red); }
.banner-title .lt-yellow { color: var(--py-yellow); }
.banner-title .lt-blue { color: var(--py-blue); }
.banner-title .lt-cream { color: #f5dc85; }
.banner-title .lt-purple { color: var(--py-purple); }

.banner-title-year {
    color: #adb0b5;
    font-size: 0.82em;
    text-shadow:
        3px 0 0 var(--ink), -3px 0 0 var(--ink),
        0 3px 0 var(--ink), 0 -3px 0 var(--ink),
        3px 3px 0 var(--ink), -3px 3px 0 var(--ink),
        3px -3px 0 var(--ink), -3px -3px 0 var(--ink),
        5px 5px 0 rgba(26, 26, 26, 0.35);
}

.cta-buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 14px;
}

.cta-buttons > a {
    display: inline-flex;
    min-height: 48px;
    align-items: center;
    justify-content: center;
    padding: 10px 18px;
    --brick-color: var(--py-yellow);
    border: 0;
    border-radius: 9px;
    background: var(--brick-color);
    box-shadow: 0 var(--brick-depth) 0 color-mix(in srgb, var(--brick-color) 68%, #000);
    color: var(--ink);
    font-weight: 700;
    text-decoration: none;
}

.cta-buttons > a:nth-child(2n) { --brick-color: var(--py-blue); }
.cta-buttons > a:nth-child(3n) { --brick-color: var(--py-red); }

.cta-buttons > a:hover {
    box-shadow: 0 calc(var(--brick-depth) + 3px) 0 color-mix(in srgb, var(--brick-color) 68%, #000);
    color: var(--ink);
    transform: translate(2px, 2px);
}

.home-brick-wall {
    column-count: 1;
    width: min(calc(100% - 48px), 1080px);
    padding: 26px 0 80px;
}

.home-highlights {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr 1fr;
    gap: 22px;
    width: min(calc(100% - 48px), 1080px);
    margin: 0 auto;
    padding: 32px 0 12px;
}

.home-highlight {
    --brick-color: var(--py-yellow);
    --brick-on: var(--ink);
    position: relative;
    min-height: 190px;
    padding: 30px 24px 24px;
    border-radius: 12px;
    background: var(--brick-color);
    background-image: linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0) 38%);
    box-shadow: 0 var(--brick-depth) 0 color-mix(in srgb, var(--brick-color) 68%, #000);
    color: var(--brick-on);
}

.home-highlight::before,
.home-highlight::after {
    position: absolute;
    left: 22px;
    right: 22px;
    background-repeat: repeat-x;
    background-size: 30px 18px;
    content: "";
    pointer-events: none;
}

.home-highlight::before {
    top: -9px;
    height: 18px;
    background-image: radial-gradient(circle at 9px center, color-mix(in srgb, var(--brick-color) 82%, #000) 0 7px, transparent 7px);
}

.home-highlight::after {
    top: -9px;
    height: 9px;
    background-image: radial-gradient(circle at 9px 4px, rgba(255, 255, 255, 0.35) 0 5px, transparent 5px);
}

/* Hover feedback via deeper plastic edge only — transform would fight the
   stagger offsets on .highlight-purple/.highlight-red. Text keeps --brick-on. */
.home-highlight:hover {
    box-shadow: 0 calc(var(--brick-depth) + 3px) 0 color-mix(in srgb, var(--brick-color) 62%, #000);
}

.home-highlight h2 { color: inherit; font-size: 1.35rem; }
.home-highlight p { margin: 0; }
.highlight-label { margin-bottom: 10px !important; font-family: var(--font-pixel); font-size: 0.62rem; }
.home-highlight { text-decoration: none; }
.highlight-purple { --brick-color: var(--py-purple); --brick-on: var(--brick-on-dark); transform: translateY(16px); }
.highlight-blue { --brick-color: var(--py-blue); }
.highlight-red { --brick-color: var(--py-red); --brick-on: var(--brick-on-light); transform: translateY(28px); }
.highlight-yellow { --brick-color: var(--py-yellow); }
.highlight-green { --brick-color: var(--py-green); }

.home-brick-wall .home-brick {
    break-inside: avoid;
    display: inline-block;
    width: 100%;
    margin: 0 0 30px;
}


.brick-yellow { --brick-color: var(--py-yellow); --brick-on: var(--brick-on-light); }
.brick-blue { --brick-color: var(--py-blue); --brick-on: var(--brick-on-light); }
.brick-red { --brick-color: var(--py-red); --brick-on: var(--brick-on-light); }
.brick-green { --brick-color: var(--py-green); --brick-on: var(--brick-on-light); }
.brick-purple { --brick-color: var(--py-purple); --brick-on: var(--brick-on-dark); }

.home-brick .card-body {
    padding: 14px;
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.88);
    color: var(--ink);
}

@media (max-width: 900px) {
    .home-highlights { grid-template-columns: 1fr 1fr; }
    .home-highlight:last-child { grid-column: 1 / -1; transform: none; }
}

@media (max-width: 560px) {
    .banner {
        min-height: 520px;
        background-position: center;
    }

    .banner-title {
        gap: 0.28em;
        font-size: 1.45rem;
    }


    .home-brick-wall { width: min(calc(100% - 28px), 640px); }

    .home-highlights { grid-template-columns: 1fr; width: min(calc(100% - 28px), 640px); }
    .highlight-purple,
    .highlight-red { transform: none; }
}
