/*
Theme Name: Pride in Dallas
Theme URI: https://dfw.dog/support
Author: Pride in Dallas
Author URI: https://dfw.dog/axel
Description: An editorial, photography-forward WordPress block theme for Pride in Dallas, a 100% volunteer-based grassroots nonprofit celebrating LGBTQ+ community in Dallas, rooted in Oak Lawn and Cedar Springs.
Version: 6.5.1
Requires at least: 6.5
Tested up to: 6.9
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: pride-in-dallas
Domain Path: /languages
Update URI: false
Tags: block-theme, full-site-editing, one-column, editor-style, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, rtl-language-support, blog, nonprofit, news
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
    --pid-canvas: #FFFFFF;
    --pid-canvas-warm: #FAF7F2;
    --pid-ink: #0D0D0D;
    --pid-ink-muted: #4A4550;
    --pid-rule: #E8E4DC;

    --pid-purple: #7E00FE;
    --pid-deep-blue: #004DFF;
    --pid-magenta: #E91E8C;
    --pid-magenta-dark: #C40F70;
    --pid-yellow: #FFB400;

    --pid-surface-dark: #0D0B14;
    --pid-surface-dark-elevated: #1A1528;

    --pid-rainbow: linear-gradient(90deg, #E40303, #FF8C00, #FFED00, #008026, #004DFF, #750787);
    --pid-brand: linear-gradient(135deg, #7E00FE 0%, #004DFF 100%);

    --pid-serif: 'Fraunces', Georgia, serif;
    --pid-sans: 'DM Sans', -apple-system, system-ui, sans-serif;
    --pid-mono: 'JetBrains Mono', ui-monospace, Menlo, monospace;

    --pid-ease: cubic-bezier(0.22, 1, 0.36, 1);
    --pid-wide: 1280px;
    --pid-announcement-h: 36px;
}

/* ============================================================
   SKIP LINK (accessibility)
   ============================================================ */
.pid-skip-link {
    position: absolute;
    left: 1rem;
    top: -40px;
    z-index: 200;
    background: var(--pid-ink);
    color: var(--pid-canvas);
    padding: 0.75rem 1.25rem;
    font-family: var(--pid-sans);
    font-weight: 600;
    font-size: 0.875rem;
    text-decoration: none;
    border-radius: 2px;
    transition: top 0.2s ease;
}
.pid-skip-link:focus {
    top: 1rem;
    outline: 2px solid var(--pid-purple);
    outline-offset: 2px;
}

/* ============================================================
   BASE RESET
   ============================================================ */
@media (prefers-reduced-motion: no-preference) {
    html { scroll-behavior: smooth; }
}

html {
    background: var(--pid-canvas);
    text-rendering: optimizeLegibility;
    text-size-adjust: 100%;
}

body {
    overflow-x: hidden;
    background: var(--pid-canvas) !important;
    color: var(--pid-ink);
    font-family: var(--pid-sans);
    font-synthesis: none;
}

.wp-site-blocks > footer { margin: 0; }

img { max-width: 100%; height: auto; display: block; }
figure { margin: 0; }

::selection { background: var(--pid-ink); color: var(--pid-canvas); }

/* Respect WP custom grids */
.events-row.is-layout-flow > *,
.mission-icons-grid.is-layout-flow > *,
.support-grid.is-layout-flow > *,
.stats-inner.is-layout-flex > *,
.countdown-inner.is-layout-flex > * {
    max-width: none !important;
    margin-inline: 0 !important;
}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1, h2, h3, h4, h5, h6,
.wp-block-heading {
    font-family: var(--pid-serif);
    font-weight: 600;
    line-height: 1.15;
    letter-spacing: -0.01em;
    color: var(--pid-ink);
    text-wrap: balance;
    overflow-wrap: break-word;
    font-optical-sizing: auto;
    hyphens: manual;
}

h1, .wp-block-post-title { font-size: clamp(2.75rem, 6vw, 4.5rem); letter-spacing: -0.02em; line-height: 1.05; }
h2 { font-size: clamp(2.25rem, 4vw, 3rem); line-height: 1.1; }
h3 { font-size: 2.25rem; line-height: 1.15; }
h4 { font-size: 1.5rem; font-weight: 500; line-height: 1.2; }

p {
    font-family: var(--pid-sans);
    line-height: 1.75;
    text-wrap: pretty;
    overflow-wrap: break-word;
}

.eyebrow,
.pid-eyebrow {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    display: inline-block;
    margin-bottom: 0.75rem;
}

/* Editorial links, underline, brand on hover */
.entry-content a,
.wp-block-post-content a {
    color: var(--pid-ink);
    text-decoration: underline;
    text-underline-offset: 0.15em;
    text-decoration-thickness: 1px;
    transition: color 0.15s ease;
}
.entry-content a:hover,
.wp-block-post-content a:hover {
    color: var(--pid-purple);
}

/* Long-form article content, comfortable editorial reading width & rhythm */
.wp-block-post-content > p,
.wp-block-post-content > ul,
.wp-block-post-content > ol {
    line-height: 1.75;
}
.wp-block-post-content > h2,
.wp-block-post-content > h3,
.wp-block-post-content > h4 {
    margin-top: 2.25rem;
    margin-bottom: 0.75rem;
}
.wp-block-post-content > h2 { font-size: clamp(1.75rem, 3vw, 2.25rem); line-height: 1.2; }
.wp-block-post-content > h3 { font-size: clamp(1.375rem, 2.5vw, 1.625rem); line-height: 1.25; }
.wp-block-post-content > p + p {
    margin-top: 1.25em;
}
.wp-block-post-content > ul,
.wp-block-post-content > ol {
    padding-left: 1.5rem;
    margin: 1.25rem 0 1.75rem;
}
.wp-block-post-content > ul li,
.wp-block-post-content > ol li {
    margin-bottom: 0.625rem;
    line-height: 1.65;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.wp-block-button__link,
.wp-element-button {
    background: var(--pid-ink);
    color: var(--pid-canvas);
    border: 1px solid var(--pid-ink);
    border-radius: 2px;
    font-family: var(--pid-sans);
    font-weight: 600;
    font-size: 0.9375rem;
    text-transform: none;
    letter-spacing: 0;
    padding: 0.875rem 1.5rem;
    transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
    display: inline-block;
    text-decoration: none;
}

.wp-block-button__link:hover,
.wp-element-button:hover {
    background: var(--pid-purple);
    border-color: var(--pid-purple);
    color: var(--pid-canvas);
}

.wp-block-button.is-style-outline .wp-block-button__link,
.wp-block-button.is-style-outline .wp-element-button {
    background: transparent;
    color: var(--pid-ink);
    border: 1px solid var(--pid-ink);
}
.wp-block-button.is-style-outline .wp-block-button__link:hover,
.wp-block-button.is-style-outline .wp-element-button:hover {
    background: var(--pid-ink);
    color: var(--pid-canvas);
}

/* ============================================================
   ANNOUNCEMENT BAR
   ============================================================ */
.announcement-bar {
    background: var(--pid-ink);
    color: var(--pid-canvas);
    height: var(--pid-announcement-h);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-align: center;
    padding: 0 1.25rem;
    position: relative;
    z-index: 110;
}
.announcement-bar a {
    color: var(--pid-canvas);
    text-decoration: underline;
    text-underline-offset: 0.2em;
}
.announcement-bar a:hover { color: var(--pid-magenta); }

/* ============================================================
   HEADER
   ============================================================ */
.header-rainbow-bar {
    height: 4px;
    min-height: 4px;
    background: var(--pid-rainbow);
}

.site-header-wrap {
    position: sticky;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    background: var(--pid-canvas);
    border-bottom: 1px solid var(--pid-rule);
    box-shadow: none;
    transition: box-shadow 0.25s ease;
}

.site-header-wrap.header-scrolled {
    box-shadow: 0 1px 0 var(--pid-rule), 0 8px 24px -18px rgba(13, 13, 13, 0.15);
}

.site-header-wrap > .wp-block-group.alignwide {
    max-width: var(--pid-wide);
    margin-inline: auto;
}

.site-header-wrap .is-layout-flex { gap: 1.5rem; }

.site-header-wrap .wp-block-image img {
    max-height: 40px;
    width: auto;
    display: block;
    flex-shrink: 0;
}

.site-header-wrap .wp-block-navigation .wp-block-navigation-item a {
    color: var(--pid-ink);
    font-family: var(--pid-sans);
    font-weight: 500;
    font-size: 0.9375rem;
    letter-spacing: 0;
    padding: 0.75rem 0.875rem;
    white-space: nowrap;
    transition: color 0.15s ease;
    text-decoration: none;
}

.site-header-wrap .wp-block-navigation .wp-block-navigation-item a:hover {
    color: var(--pid-purple);
}

.site-header-wrap .wp-block-navigation__responsive-container-open { color: var(--pid-ink); }
.site-header-wrap .wp-block-navigation__responsive-container.is-menu-open { background: var(--pid-canvas); }
.site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a {
    color: var(--pid-ink);
    font-size: 1.25rem;
    padding: 1rem 1.25rem;
    font-family: var(--pid-serif);
    font-weight: 500;
}

/* ----- Desktop submenu flyouts ----- */
.site-header-wrap .wp-block-navigation-submenu {
    position: relative;
}
/* Invisible hover-bridge so mouse can pass from parent link to submenu
   flyout without dropping the hover (fixes the "submenu disappears before
   I can click" problem). */
.site-header-wrap .wp-block-navigation-submenu::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    height: 0.75rem;
    pointer-events: auto;
    background: transparent;
}
.site-header-wrap .wp-block-navigation-submenu > .wp-block-navigation-item__content {
    padding-right: 1.25rem;
}
.site-header-wrap .wp-block-navigation-submenu__toggle {
    background: transparent;
    border: 0;
    padding: 0.375rem 0.25rem 0.375rem 0;
    color: var(--pid-ink);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
}
.site-header-wrap .wp-block-navigation-submenu__toggle svg {
    fill: currentColor;
    stroke: currentColor;
    width: 10px;
    height: 10px;
    margin-left: -0.375rem;
}
.site-header-wrap .wp-block-navigation__submenu-container {
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-radius: 2px;
    box-shadow: 0 18px 40px -24px rgba(13, 13, 13, 0.2);
    min-width: 240px;
    padding: 0.5rem 0;
    margin-top: 0;
    top: calc(100% + 0.5rem);
    z-index: 110;
}
.site-header-wrap .wp-block-navigation__submenu-container .wp-block-navigation-item a {
    padding: 0.625rem 1.25rem;
    font-family: var(--pid-sans);
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--pid-ink);
    white-space: nowrap;
    transition: background 0.15s ease, color 0.15s ease;
}
.site-header-wrap .wp-block-navigation__submenu-container .wp-block-navigation-item a:hover {
    background: var(--pid-canvas-warm);
    color: var(--pid-purple);
}

.site-header-wrap .nav-donate-cta .wp-block-button__link {
    background: var(--pid-magenta);
    color: var(--pid-canvas);
    font-family: var(--pid-sans);
    font-weight: 600;
    font-size: 0.8125rem;
    padding: 0.5rem 1.25rem;
    border-radius: 2px;
    text-transform: none;
    letter-spacing: 0;
    border: 1px solid var(--pid-magenta);
    white-space: nowrap;
    transition: background 0.2s ease, border-color 0.2s ease;
}
.site-header-wrap .nav-donate-cta .wp-block-button__link:hover {
    background: var(--pid-magenta-dark);
    border-color: var(--pid-magenta-dark);
}

/* ============================================================
   EDITORIAL HERO (new pattern-ready selectors)
   ============================================================ */
.hero-editorial {
    position: relative;
    min-height: min(70vh, 640px);
    overflow: hidden;
    background: var(--pid-canvas-warm);
}
.hero-editorial__image {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    will-change: transform;
}
.hero-editorial__image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0.08) 0%, rgba(0,0,0,0) 40%, rgba(0,0,0,0.25) 100%);
}
/* Cover's inner container becomes a flex container that pins its child
   (the hero card) to the bottom-left of the cover. Avoids position:absolute
   stacking issues with WP core's cover block layers. */
.hero-editorial .wp-block-cover__inner-container,
.hero-editorial__cover > .wp-block-cover__inner-container {
    display: flex !important;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    padding: clamp(1.5rem, 5vw, 3.5rem) clamp(1.25rem, 5vw, 4rem);
    min-height: 100%;
    box-sizing: border-box;
}
.hero-editorial__card {
    position: relative;
    z-index: 3;
    max-width: min(620px, 100%);
    background: var(--pid-canvas);
    padding: clamp(1.75rem, 3.5vw, 2.75rem) clamp(1.75rem, 3.5vw, 2.75rem) clamp(1.75rem, 3.5vw, 2.5rem) clamp(2.25rem, 4vw, 3.25rem);
    border-left: 4px solid var(--pid-magenta);
    border-radius: 0 2px 2px 0;
    box-shadow: 0 20px 60px -24px rgba(13, 13, 13, 0.5);
}
.hero-editorial__card .eyebrow,
.hero-editorial__eyebrow {
    margin: 0 0 1rem;
    color: var(--pid-magenta);
    font-weight: 600;
}
.hero-editorial__card h1,
.hero-editorial__headline {
    font-family: var(--pid-serif);
    font-size: clamp(2.25rem, 5.5vw, 4rem);
    line-height: 0.95;
    font-weight: 600;
    margin: 0 0 1.25rem;
    color: var(--pid-ink);
    display: flex;
    flex-direction: column;
    gap: 0.15em;
}
.hero-editorial__headline-line {
    display: block;
    text-wrap: balance;
}
.hero-editorial__headline-line--accent {
    position: relative;
    display: inline-block;
    align-self: flex-start;
    color: var(--pid-ink);
    padding: 0 0.1em;
}
.hero-editorial__headline-line--accent::before {
    content: "";
    position: absolute;
    inset: 0.12em 0 0.08em;
    background: linear-gradient(180deg, transparent 55%, var(--pid-magenta) 55%, var(--pid-magenta) 92%, transparent 92%);
    z-index: -1;
    opacity: 0.9;
    transform: skewX(-4deg);
}
.hero-editorial__card .lede,
.hero-editorial__lede {
    font-family: var(--pid-sans);
    font-size: clamp(1rem, 1.4vw, 1.125rem);
    line-height: 1.6;
    color: var(--pid-ink-muted);
    margin: 0 0 1.75rem;
    text-wrap: pretty;
    max-width: 52ch;
}
.hero-editorial__actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}
.hero-editorial__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.625rem;
    font-family: var(--pid-mono);
    font-size: 0.8125rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-weight: 600;
    text-decoration: none;
    padding: 0.95rem 1.5rem;
    border-radius: 2px;
    transition: transform 0.2s var(--pid-ease), background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.hero-editorial__btn--primary {
    background: var(--pid-ink);
    color: var(--pid-canvas);
    border: 1px solid var(--pid-ink);
}
.hero-editorial__btn--primary:hover {
    background: var(--pid-magenta);
    border-color: var(--pid-magenta);
    transform: translateY(-2px);
}
.hero-editorial__btn--secondary {
    background: transparent;
    color: var(--pid-ink);
    border: 1px solid var(--pid-ink);
}
.hero-editorial__btn--secondary:hover {
    background: var(--pid-ink);
    color: var(--pid-canvas);
    transform: translateY(-2px);
}
.hero-editorial__btn-arrow {
    display: inline-block;
    transition: transform 0.2s var(--pid-ease);
}
.hero-editorial__btn:hover .hero-editorial__btn-arrow {
    transform: translateX(3px);
}

/* ============================================================
   FULLSCREEN HERO CAROUSEL (homepage)
   Each slide is a real wp:cover block; we stack them absolutely
   and toggle .is-active with JS. Fade + subtle scale transition.

   Sizing: the carousel fills the viewport MINUS the site nav height
   so that nav + carousel = one screen on first load, with no content
   cut off at the bottom. The --pid-nav-height custom property is
   measured and updated by JS on load + resize (see the carousel script
   in functions.php). Fallback of 80px covers the nav's typical height
   before JS runs so there's no pop.
   ============================================================ */
:root {
    --pid-nav-height: 80px;
}
.pid-hero-carousel {
    position: relative;
    width: 100%;
    height: calc(100vh - var(--pid-nav-height, 80px));
    height: calc(100dvh - var(--pid-nav-height, 80px));
    min-height: 560px;
    overflow: hidden;
    background: var(--pid-ink);
    isolation: isolate;
}
.pid-hero-carousel__slide {
    position: absolute !important;
    inset: 0;
    width: 100%;
    height: 100% !important;
    min-height: 100% !important;
    margin: 0 !important;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: scale(1.04);
    transition: opacity 0.9s var(--pid-ease), visibility 0s linear 0.9s, transform 7s var(--pid-ease);
    z-index: 1;
}
.pid-hero-carousel__slide.is-active {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: scale(1);
    transition: opacity 0.9s var(--pid-ease), visibility 0s linear 0s, transform 7s var(--pid-ease);
    z-index: 2;
}
/* The Cover's dark dim layer, darken a bit more so the card always has contrast */
.pid-hero-carousel__slide .wp-block-cover__background {
    background: linear-gradient(180deg, rgba(13,13,13,0.25) 0%, rgba(13,13,13,0.35) 40%, rgba(13,13,13,0.7) 100%) !important;
    opacity: 1 !important;
}
.pid-hero-carousel__slide .wp-block-cover__image-background {
    object-fit: cover;
    transform: scale(1.02);
}
/* Pin the slide's inner-container so the card sits in the bottom-left of the viewport */
.pid-hero-carousel__slide .wp-block-cover__inner-container {
    display: flex !important;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    padding: clamp(2rem, 6vw, 5rem) clamp(1.5rem, 6vw, 5rem) clamp(7rem, 10vw, 9rem);
    min-height: 100%;
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
}

/* The editorial card that holds the slide's copy */
.pid-hero-carousel__card {
    position: relative;
    z-index: 3;
    max-width: min(680px, 100%);
    background: var(--pid-canvas);
    padding: clamp(1.75rem, 3.5vw, 3rem) clamp(1.75rem, 3.5vw, 3rem) clamp(1.75rem, 3.5vw, 2.75rem) clamp(2.25rem, 4vw, 3.5rem);
    border-left: 4px solid var(--pid-magenta);
    border-radius: 0 2px 2px 0;
    box-shadow: 0 30px 80px -24px rgba(0, 0, 0, 0.6);
    opacity: 0;
    transform: translateY(18px);
    transition: opacity 0.8s var(--pid-ease) 0.3s, transform 0.8s var(--pid-ease) 0.3s;
}
.pid-hero-carousel__slide.is-active .pid-hero-carousel__card {
    opacity: 1;
    transform: translateY(0);
}
.pid-hero-carousel__eyebrow {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--pid-magenta);
    font-weight: 600;
    margin: 0 0 1rem;
}
.pid-hero-carousel__headline {
    font-family: var(--pid-serif);
    font-size: clamp(2.25rem, 6vw, 4.5rem);
    line-height: 0.95;
    font-weight: 600;
    margin: 0 0 1.25rem;
    color: var(--pid-ink);
    display: flex;
    flex-direction: column;
    gap: 0.1em;
}
.pid-hero-carousel__line {
    display: block;
    text-wrap: balance;
}
.pid-hero-carousel__line--accent {
    position: relative;
    display: inline-block;
    align-self: flex-start;
    color: var(--pid-ink);
    padding: 0 0.1em;
}
.pid-hero-carousel__line--accent::before {
    content: "";
    position: absolute;
    inset: 0.12em 0 0.08em;
    background: linear-gradient(180deg, transparent 55%, var(--pid-magenta) 55%, var(--pid-magenta) 92%, transparent 92%);
    z-index: -1;
    opacity: 0.9;
    transform: skewX(-4deg);
}
.pid-hero-carousel__lede {
    font-family: var(--pid-sans);
    font-size: clamp(1rem, 1.4vw, 1.125rem);
    line-height: 1.6;
    color: var(--pid-ink-muted);
    margin: 0 0 1.75rem;
    text-wrap: pretty;
    max-width: 54ch;
}
.pid-hero-carousel__actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}
.pid-hero-carousel__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.625rem;
    font-family: var(--pid-mono);
    font-size: 0.8125rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-weight: 600;
    text-decoration: none;
    padding: 1rem 1.625rem;
    border-radius: 2px;
    min-height: 48px;
    transition: transform 0.2s var(--pid-ease), background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.pid-hero-carousel__btn--primary {
    background: var(--pid-ink);
    color: var(--pid-canvas);
    border: 1px solid var(--pid-ink);
}
.pid-hero-carousel__btn--primary:hover {
    background: var(--pid-magenta);
    border-color: var(--pid-magenta);
    transform: translateY(-2px);
}
.pid-hero-carousel__btn--secondary {
    background: transparent;
    color: var(--pid-ink);
    border: 1px solid var(--pid-ink);
}
.pid-hero-carousel__btn--secondary:hover {
    background: var(--pid-ink);
    color: var(--pid-canvas);
    transform: translateY(-2px);
}
.pid-hero-carousel__btn-arrow {
    display: inline-block;
    transition: transform 0.2s var(--pid-ease);
}
.pid-hero-carousel__btn:hover .pid-hero-carousel__btn-arrow {
    transform: translateX(3px);
}

/* ============================================================
   CAROUSEL CONTROLS (dots, arrows, play/pause, progress bar)
   ============================================================ */
.pid-hero-carousel__controls {
    position: absolute;
    left: 0;
    right: 0;
    bottom: clamp(2rem, 4vw, 3rem);
    z-index: 5;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: clamp(0.75rem, 2vw, 1.5rem);
    padding: 0 clamp(1rem, 4vw, 2.5rem);
}
.pid-hero-carousel__arrow {
    flex-shrink: 0;
    width: 52px;
    height: 52px;
    min-width: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(13, 13, 13, 0.55);
    border: 1px solid rgba(255, 255, 255, 0.3);
    color: var(--pid-canvas);
    border-radius: 50%;
    font-size: 1.75rem;
    line-height: 1;
    font-family: var(--pid-serif);
    padding: 0 0 0.1em 0;
    cursor: pointer;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s var(--pid-ease);
}
.pid-hero-carousel__arrow:hover {
    background: var(--pid-magenta);
    border-color: var(--pid-magenta);
    transform: scale(1.08);
}
.pid-hero-carousel__arrow:focus-visible {
    outline: 2px solid var(--pid-canvas);
    outline-offset: 3px;
}
.pid-hero-carousel__arrow--prev span { padding-right: 0.1em; }
.pid-hero-carousel__arrow--next span { padding-left: 0.1em; }

.pid-hero-carousel__dots {
    display: flex;
    align-items: center;
    gap: 0.625rem;
}
.pid-hero-carousel__dot {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    min-height: 44px;
    min-width: 44px;
    padding: 0;
    background: transparent;
    border: 0;
    cursor: pointer;
    position: relative;
}
.pid-hero-carousel__dot::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.4);
    border: 1px solid rgba(255, 255, 255, 0.7);
    transform: translate(-50%, -50%);
    transition: width 0.25s var(--pid-ease), background 0.25s ease, border-color 0.25s ease;
}
.pid-hero-carousel__dot:hover::before {
    background: rgba(255, 255, 255, 0.85);
}
.pid-hero-carousel__dot.is-active::before {
    width: 28px;
    border-radius: 5px;
    background: var(--pid-magenta);
    border-color: var(--pid-magenta);
}
.pid-hero-carousel__dot:focus-visible {
    outline: 2px solid var(--pid-canvas);
    outline-offset: 2px;
    border-radius: 4px;
}

.pid-hero-carousel__playpause {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    min-width: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.3);
    color: var(--pid-canvas);
    border-radius: 50%;
    font-size: 0.75rem;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease;
}
.pid-hero-carousel__playpause:hover {
    background: rgba(255, 255, 255, 0.15);
    border-color: rgba(255, 255, 255, 0.55);
}
.pid-hero-carousel__playpause:focus-visible {
    outline: 2px solid var(--pid-canvas);
    outline-offset: 2px;
}

/* Progress bar at bottom, animates its width from 0 → 100% each cycle */
.pid-hero-carousel__progress {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 3px;
    background: rgba(255, 255, 255, 0.15);
    z-index: 4;
    pointer-events: none;
}
.pid-hero-carousel__progress-bar {
    height: 100%;
    width: 0%;
    background: var(--pid-magenta);
    box-shadow: 0 0 12px rgba(240, 42, 161, 0.6);
    will-change: width;
    transition: width 0.15s linear;
}
.pid-hero-carousel.is-paused .pid-hero-carousel__progress-bar {
    background: rgba(255, 255, 255, 0.6);
    box-shadow: none;
}

/* Mobile tuning */
@media (max-width: 700px) {
    .pid-hero-carousel { min-height: 560px; }
    .pid-hero-carousel__slide .wp-block-cover__inner-container {
        padding: clamp(1.5rem, 5vw, 3rem) 1.25rem clamp(7rem, 10vw, 8.5rem);
    }
    .pid-hero-carousel__card {
        padding: 1.5rem 1.5rem 1.5rem 1.75rem;
        border-left-width: 3px;
    }
    .pid-hero-carousel__arrow {
        width: 44px;
        height: 44px;
        min-width: 44px;
        font-size: 1.5rem;
    }
    .pid-hero-carousel__controls {
        gap: 0.625rem;
        bottom: 1.5rem;
    }
    .pid-hero-carousel__headline {
        font-size: clamp(2rem, 9vw, 3rem);
    }
}
@media (max-width: 480px) {
    .pid-hero-carousel__dots { gap: 0.375rem; }
    .pid-hero-carousel__playpause { display: none; } /* dots are enough on small screens */
}

/* Reduced motion, honor the user preference */
@media (prefers-reduced-motion: reduce) {
    .pid-hero-carousel__slide {
        transition: opacity 0.3s linear, visibility 0s linear 0.3s;
        transform: none !important;
    }
    .pid-hero-carousel__slide.is-active {
        transition: opacity 0.3s linear, visibility 0s linear 0s;
    }
    .pid-hero-carousel__slide .wp-block-cover__image-background { transform: none !important; }
    .pid-hero-carousel__card {
        transition: none;
        transform: none !important;
    }
    .pid-hero-carousel__progress-bar { transition: none; }
}

/* Also hide the slide for screen readers when inactive (redundant with visibility,
   but some ATs ignore visibility:hidden) */
.pid-hero-carousel__slide[aria-hidden="true"] * {
    /* Nothing here, aria-hidden on the slide itself is the right signal */
}

/* Legacy full-bleed hero (back-compat), retuned lighter */
.hero-fullbleed-section { position: relative; }
.hero-cover {
    min-height: min(70vh, 640px) !important;
    position: relative;
}
.hero-cover.wp-block-cover { padding: 0 !important; }
.hero-cover::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0.05) 0%, rgba(0,0,0,0) 45%, rgba(0,0,0,0.35) 100%);
    pointer-events: none;
}
.hero-cover .wp-block-cover__image-background {
    transform: scale(1.04);
    transition: transform 1.2s var(--pid-ease);
}
.hero-entrance { opacity: 0; transform: translateY(12px); transition: opacity 0.8s var(--pid-ease), transform 0.8s var(--pid-ease); }
.hero-entrance.hero-loaded { opacity: 1; transform: translateY(0); }
.hero-scroll-hint {
    position: absolute;
    bottom: 1.5rem;
    right: 1.5rem;
    color: var(--pid-canvas);
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    opacity: 0.8;
    pointer-events: none;
}
.hero-scroll-hint::before {
    content: "↓";
    display: block;
    text-align: center;
    font-size: 1rem;
    animation: scrollBounce 2s ease-in-out infinite;
}

/* ============================================================
   SECTION SHELL UTILITIES
   ============================================================ */
.pid-section {
    padding-block: clamp(3rem, 6vw, 6rem);
    padding-inline: 1.25rem;
}
.pid-section--warm { background: var(--pid-canvas-warm); }
.pid-section--dark {
    background: var(--pid-surface-dark);
    color: var(--pid-canvas);
}
.pid-section--dark h1,
.pid-section--dark h2,
.pid-section--dark h3,
.pid-section--dark h4,
.pid-section--dark .wp-block-heading { color: var(--pid-canvas); }

.pid-container {
    max-width: var(--pid-wide);
    margin-inline: auto;
}

.pid-section-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 2rem;
    margin-bottom: clamp(1.5rem, 3vw, 2.5rem);
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--pid-rule);
}
.pid-section-head h2 { margin: 0; }
.pid-section-head .pid-section-link {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pid-ink);
    text-decoration: none;
    white-space: nowrap;
    border-bottom: 1px solid var(--pid-ink);
    padding-bottom: 2px;
}
.pid-section-head .pid-section-link:hover { color: var(--pid-purple); border-color: var(--pid-purple); }

/* ============================================================
   THEME MANIFESTO BLOCK (the single dark moment)
   Stacked-statement layout with oversized numerals
   ============================================================ */
.theme-manifesto {
    background: var(--pid-surface-dark);
    color: var(--pid-canvas);
    padding: clamp(5rem, 10vw, 8rem) 1.25rem;
    position: relative;
    overflow: hidden;
}
.theme-manifesto::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 15% 20%, rgba(126, 0, 254, 0.28), transparent 50%),
        radial-gradient(circle at 85% 80%, rgba(240, 42, 161, 0.2), transparent 55%);
    pointer-events: none;
}
.theme-manifesto::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 4px;
    background: linear-gradient(
        90deg,
        #E40303 0%, #E40303 16.66%,
        #FF8C00 16.66%, #FF8C00 33.33%,
        #FFED00 33.33%, #FFED00 50%,
        #008026 50%, #008026 66.66%,
        #004DFF 66.66%, #004DFF 83.33%,
        #750787 83.33%, #750787 100%
    );
    opacity: 0.75;
}
.theme-manifesto__inner {
    position: relative;
    max-width: 1000px;
    margin-inline: auto;
    text-align: left;
}
.theme-manifesto__eyebrow {
    color: var(--pid-magenta);
    margin: 0 0 2.5rem;
    font-weight: 600;
}
.theme-manifesto__stack {
    display: flex;
    flex-direction: column;
    gap: clamp(0.25rem, 1vw, 0.75rem);
    margin-bottom: 3rem;
}
.theme-manifesto__line {
    display: flex;
    align-items: baseline;
    gap: clamp(1rem, 2.5vw, 2rem);
    margin: 0;
    font-family: var(--pid-serif);
    font-size: clamp(2.25rem, 6.5vw, 5rem);
    line-height: 1;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.65);
    text-wrap: balance;
}
.theme-manifesto__num {
    font-family: var(--pid-mono);
    font-size: clamp(0.75rem, 1.1vw, 0.875rem);
    letter-spacing: 0.12em;
    color: var(--pid-magenta);
    font-weight: 600;
    align-self: flex-start;
    padding-top: 0.8em;
    flex-shrink: 0;
    min-width: 2ch;
}
.theme-manifesto__text { flex: 1; }
.theme-manifesto__line strong {
    font-weight: 600;
    color: var(--pid-canvas);
    background: linear-gradient(180deg, transparent 62%, rgba(240, 42, 161, 0.35) 62%, rgba(240, 42, 161, 0.35) 92%, transparent 92%);
    padding: 0 0.08em;
}
.theme-manifesto__tagline {
    font-family: var(--pid-sans);
    font-size: clamp(1rem, 1.4vw, 1.125rem);
    line-height: 1.65;
    color: rgba(255, 255, 255, 0.78);
    margin: 0 0 1rem;
    max-width: 58ch;
}
.theme-manifesto__cite {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.55);
    margin: 0;
}

@media (max-width: 640px) {
    .theme-manifesto__line {
        flex-direction: column;
        gap: 0.35rem;
    }
    .theme-manifesto__num { padding-top: 0; }
}

/* ============================================================
   EVENT TILES (light/editorial rebuild of existing shortcode output)
   ============================================================ */
.events-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}

.event-tile {
    display: block;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-radius: 2px;
    overflow: hidden;
    text-decoration: none;
    color: var(--pid-ink);
    transition: transform 0.3s var(--pid-ease), box-shadow 0.3s var(--pid-ease), border-color 0.2s ease;
}
.event-tile:hover {
    transform: translateY(-3px);
    box-shadow: 0 16px 32px -24px rgba(0, 0, 0, 0.3);
    border-color: var(--pid-ink);
}

/* Variant "color stripe" top border, carried over from the prior tile system */
.event-tile { border-top: 3px solid var(--pid-ink); }
.event-tile-dark    { border-top-color: var(--pid-ink); }
.event-tile-magenta { border-top-color: var(--pid-magenta); }
.event-tile-blue    { border-top-color: var(--pid-deep-blue); }
.event-tile-purple  { border-top-color: var(--pid-purple); }

.event-tile .wp-block-image { position: relative; }
.event-tile img {
    width: 100%;
    height: 220px;
    object-fit: cover;
    display: block;
    transition: transform 0.6s var(--pid-ease);
}
.event-tile:hover img { transform: scale(1.03); }

.event-tile-price {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    background: var(--pid-canvas);
    color: var(--pid-ink);
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    font-weight: 500;
    padding: 0.375rem 0.625rem;
    letter-spacing: 0.02em;
    border: 1px solid var(--pid-rule);
}

.event-tile-content {
    padding: 1.25rem 1.25rem 1.5rem;
}
.event-tile-date {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0 0 0.5rem;
}
.event-tile h3 {
    font-size: 1.375rem;
    line-height: 1.2;
    margin: 0 0 0.625rem;
    text-wrap: balance;
}
.event-tile p {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    margin: 0;
}

.events-view-all-btn {
    display: inline-block;
    background: transparent;
    color: var(--pid-ink);
    border: 1px solid var(--pid-ink);
    padding: 0.875rem 1.75rem;
    font-weight: 600;
    font-size: 0.875rem;
    text-decoration: none;
    border-radius: 2px;
    transition: all 0.2s ease;
}
.events-view-all-btn:hover {
    background: var(--pid-ink);
    color: var(--pid-canvas);
}

/* Stagger entrance */
.events-stagger .event-tile { opacity: 0; transform: translateY(14px); animation: fadeUp 0.6s var(--pid-ease) forwards; }
.events-stagger .event-tile:nth-child(1) { animation-delay: 0.05s; }
.events-stagger .event-tile:nth-child(2) { animation-delay: 0.12s; }
.events-stagger .event-tile:nth-child(3) { animation-delay: 0.19s; }
.events-stagger .event-tile:nth-child(4) { animation-delay: 0.26s; }

/* ============================================================
   EVENT ARCHIVE (shortcode output)
   ============================================================ */
.pid-archive-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 2rem;
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--pid-rule);
}
.pid-archive-filter-btn {
    display: inline-block;
    padding: 0.5rem 1rem;
    background: transparent;
    color: var(--pid-ink);
    border: 1px solid var(--pid-rule);
    border-radius: 2px;
    font-family: var(--pid-sans);
    font-size: 0.8125rem;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.15s ease;
}
.pid-archive-filter-btn:hover {
    border-color: var(--pid-ink);
    color: var(--pid-ink);
}
.pid-archive-filter-btn.is-active {
    background: var(--pid-ink);
    color: var(--pid-canvas);
    border-color: var(--pid-ink);
}

.pid-archive-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem 1.75rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}

.pid-archive-card {
    display: flex;
    flex-direction: column;
    background: var(--pid-canvas);
    text-decoration: none;
    color: var(--pid-ink);
    transition: transform 0.3s var(--pid-ease);
}
.pid-archive-card:hover { transform: translateY(-2px); }

.pid-archive-card-image {
    position: relative;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    border: 1px solid var(--pid-rule);
}
.pid-archive-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s var(--pid-ease);
}
.pid-archive-card:hover .pid-archive-card-image img { transform: scale(1.04); }

.pid-archive-price-badge {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    background: var(--pid-canvas);
    color: var(--pid-ink);
    padding: 0.375rem 0.625rem;
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.05em;
    border: 1px solid var(--pid-rule);
}
.pid-archive-category-pill {
    position: absolute;
    top: 0.75rem;
    left: 0.75rem;
    background: var(--pid-ink);
    color: var(--pid-canvas);
    padding: 0.375rem 0.625rem;
    font-family: var(--pid-mono);
    font-size: 0.625rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.pid-archive-card-content { padding: 1rem 0 0; }
.pid-archive-card-date {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0 0 0.375rem;
}
.pid-archive-card h3 {
    font-size: 1.375rem;
    line-height: 1.2;
    margin: 0 0 0.5rem;
    text-wrap: balance;
}
.pid-archive-card-location {
    font-family: var(--pid-sans);
    font-size: 0.9375rem;
    line-height: 1.5;
    color: var(--pid-ink-muted);
    margin: 0;
}
.pid-archive-ticket-link {
    display: inline-block;
    margin-top: 0.75rem;
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pid-ink);
    border-bottom: 1px solid var(--pid-ink);
    padding-bottom: 2px;
}

/* ============================================================
   EVENT HERO / CTA (single event template)
   ============================================================ */
.event-hero-section {
    position: relative;
    min-height: 56vh;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
    background: var(--pid-canvas-warm);
}
.event-hero-image {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
}
.event-hero-image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,0.7) 100%);
}
.event-hero-overlay {
    position: relative;
    width: 100%;
    padding: 3rem 1.25rem;
}
.event-hero-content {
    max-width: var(--pid-wide);
    margin-inline: auto;
    color: var(--pid-canvas);
}
.event-hero-category {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-canvas);
    opacity: 0.85;
    margin: 0 0 0.75rem;
}
.event-hero-section .event-hero-title {
    font-family: var(--pid-serif);
    font-size: clamp(2.25rem, 5vw, 4rem);
    line-height: 1.05;
    color: var(--pid-canvas);
    margin: 0 0 1rem;
    text-wrap: balance;
}
.event-hero-meta {
    font-family: var(--pid-sans);
    font-size: 1.0625rem;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.92);
    margin: 0;
}
.event-meta-divider { opacity: 0.5; margin: 0 0.25rem; }

.event-cta-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    max-width: var(--pid-wide);
    margin: 2.5rem auto;
    padding: 1.5rem 1.75rem;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-top: 3px solid var(--pid-ink);
}
.event-cta-info { display: flex; align-items: baseline; gap: 0.75rem; }
.event-cta-price {
    font-family: var(--pid-serif);
    font-size: 2rem;
    font-weight: 600;
    margin: 0;
    color: var(--pid-ink);
}
.event-cta-label {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0;
}
.event-cta-button {
    background: var(--pid-magenta);
    color: var(--pid-canvas);
    padding: 1rem 1.75rem;
    font-family: var(--pid-sans);
    font-weight: 600;
    font-size: 0.9375rem;
    text-decoration: none;
    border-radius: 2px;
    transition: background 0.2s ease;
}
.event-cta-button:hover { background: var(--pid-magenta-dark); }

/* ============================================================
   PASSES GRID
   ============================================================ */
.passes-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.75rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.pass-card {
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-radius: 2px;
    overflow: hidden;
    transition: transform 0.3s var(--pid-ease), box-shadow 0.3s var(--pid-ease);
}
.pass-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 16px 32px -24px rgba(0, 0, 0, 0.25);
}
.pass-card-image { aspect-ratio: 3 / 2; overflow: hidden; }
.pass-card-image img { width: 100%; height: 100%; object-fit: cover; }
.pass-card-content { padding: 1.5rem; }
.pass-card-price {
    font-family: var(--pid-serif);
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--pid-ink);
    margin: 0 0 0.25rem;
}
.pass-card-title {
    font-family: var(--pid-serif);
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1.2;
    margin: 0 0 0.5rem;
    text-wrap: balance;
}
.pass-card-description {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    margin: 0 0 1.25rem;
}
.pass-card-cta {
    display: inline-block;
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pid-ink);
    text-decoration: none;
    border-bottom: 1px solid var(--pid-ink);
    padding-bottom: 2px;
}

/* ============================================================
   COUNTDOWN RIBBON (lighter)
   ============================================================ */
.countdown-bar {
    background: var(--pid-canvas-warm);
    border-block: 1px solid var(--pid-rule);
    padding: 1.5rem 1.25rem;
}
.countdown-inner {
    max-width: var(--pid-wide);
    margin-inline: auto;
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 2.5rem;
    flex-wrap: wrap;
}
.countdown-label {
    font-family: var(--pid-mono);
    font-size: 0.8125rem;
    line-height: 1.5;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
}
.countdown-unit { text-align: center; min-width: 72px; }
.countdown-days, .countdown-hours, .countdown-mins, .countdown-secs {
    display: block;
    font-family: var(--pid-serif);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 600;
    line-height: 1;
    color: var(--pid-ink);
    font-variant-numeric: tabular-nums;
}
.countdown-unit-label {
    display: block;
    margin-top: 0.25rem;
    font-family: var(--pid-mono);
    font-size: 0.625rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
}

/* ============================================================
   STATS BAR (lighter)
   ============================================================ */
.stats-inner {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    gap: 2rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
}
.stat-item { text-align: center; min-width: 140px; }
.stat-number {
    display: block;
    font-family: var(--pid-serif);
    font-size: clamp(2.5rem, 5vw, 3.5rem);
    font-weight: 600;
    line-height: 1;
    color: var(--pid-ink);
    font-variant-numeric: tabular-nums;
}
.stat-label {
    display: block;
    margin-top: 0.5rem;
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
}

/* ============================================================
   RECEIPTS SECTION (real-data transparency block)
   ============================================================ */
.receipts-section {
    background: var(--pid-canvas);
    position: relative;
}
.receipts-section::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 1px;
    background: var(--pid-rule);
}
.receipts-lede {
    max-width: 640px;
}
.receipts-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    max-width: var(--pid-wide);
    margin-inline: auto;
    border-top: 2px solid var(--pid-ink);
    border-bottom: 2px solid var(--pid-ink);
}
.receipts-tile {
    padding: clamp(2rem, 4vw, 3rem) clamp(1.25rem, 2.5vw, 2rem);
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
    border-right: 1px solid var(--pid-rule);
    position: relative;
    transition: background 0.3s var(--pid-ease);
}
.receipts-tile:last-child { border-right: 0; }
.receipts-tile:hover {
    background: var(--pid-canvas-warm);
}
.receipts-tile::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 3px;
    height: 0;
    background: var(--pid-magenta);
    transition: height 0.3s var(--pid-ease);
}
.receipts-tile:hover::after { height: 100%; }

.receipts-tile__num {
    display: block;
    font-family: var(--pid-serif);
    font-size: clamp(3rem, 6vw, 4.5rem);
    font-weight: 600;
    line-height: 0.95;
    color: var(--pid-ink);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.01em;
}
.receipts-tile__num--text {
    font-size: clamp(2.5rem, 5vw, 3.5rem);
}
.receipts-tile__num-suffix {
    font-size: 0.5em;
    font-weight: 500;
    color: var(--pid-magenta);
    display: inline-block;
    margin-left: 0.1em;
    vertical-align: baseline;
}
.receipts-tile__label {
    display: block;
    font-family: var(--pid-sans);
    font-size: 1rem;
    font-weight: 500;
    color: var(--pid-ink);
    line-height: 1.3;
    margin-top: 0.25rem;
}
.receipts-tile__note {
    display: block;
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin-top: auto;
    padding-top: 0.5rem;
}
.receipts-footnote {
    color: var(--pid-ink-muted);
    max-width: 720px;
    margin-inline: auto;
}
.receipts-footnote a {
    color: var(--pid-ink);
    text-decoration: underline;
    text-underline-offset: 3px;
    font-weight: 500;
}
.receipts-footnote a:hover { color: var(--pid-magenta); }

@media (max-width: 900px) {
    .receipts-grid { grid-template-columns: repeat(2, 1fr); }
    .receipts-tile:nth-child(2) { border-right: 0; }
    .receipts-tile:nth-child(1),
    .receipts-tile:nth-child(2) { border-bottom: 1px solid var(--pid-rule); }
}
@media (max-width: 520px) {
    .receipts-grid { grid-template-columns: 1fr; }
    .receipts-tile {
        border-right: 0;
        border-bottom: 1px solid var(--pid-rule);
    }
    .receipts-tile:last-child { border-bottom: 0; }
}

/* ============================================================
   MARQUEE (retained, restyled light)
   ============================================================ */
.marquee-wrap {
    background: var(--pid-ink);
    color: var(--pid-canvas);
    padding: 0.875rem 0;
    overflow: hidden;
    border-block: 1px solid var(--pid-ink);
}
.marquee-track {
    display: flex;
    gap: 3rem;
    white-space: nowrap;
    animation: marquee-scroll 35s linear infinite;
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
}

/* ============================================================
   MISSION / SUPPORT / QUOTE patterns (light)
   ============================================================ */
.mission-icons-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
}
.mission-icon-card {
    text-align: center;
    padding: 1.5rem 1rem;
    border-top: 1px solid var(--pid-rule);
}
.mission-icon-card h4 {
    font-family: var(--pid-serif);
    font-size: 1.125rem;
    margin: 0.75rem 0 0.375rem;
}
.mission-icon-card p {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    margin: 0;
}

.support-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.75rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
}

/* ============================================================
   PATTERN: STORY GRID
   ============================================================ */
.story-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem 1.75rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.story-card {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: var(--pid-ink);
    transition: transform 0.3s var(--pid-ease);
}
.story-card:hover { transform: translateY(-2px); }
.story-card__image {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    border: 1px solid var(--pid-rule);
}
.story-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s var(--pid-ease);
}
.story-card:hover .story-card__image img { transform: scale(1.04); }
.story-card__body { padding: 1.25rem 0 0; }
.story-card__eyebrow {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0 0 0.5rem;
}
.story-card__title {
    font-family: var(--pid-serif);
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.15;
    margin: 0 0 0.5rem;
    color: var(--pid-ink);
}
.story-card__deck {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    margin: 0;
}

/* ============================================================
   PATTERN: COMMUNITY GRID
   ============================================================ */
.community-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.community-tile {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    text-decoration: none;
    color: var(--pid-ink);
    overflow: hidden;
    transition: transform 0.3s var(--pid-ease), box-shadow 0.3s var(--pid-ease);
}
.community-tile:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 40px -24px rgba(0, 0, 0, 0.3);
}
.community-tile__image {
    aspect-ratio: 5 / 3;
    overflow: hidden;
}
.community-tile__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s var(--pid-ease);
}
.community-tile:hover .community-tile__image img { transform: scale(1.04); }
.community-tile__flag {
    display: block;
    height: 6px;
    width: 100%;
}
.community-tile__body { padding: 1.25rem 1.25rem 1.5rem; }
.community-tile__title {
    font-family: var(--pid-serif);
    font-size: 1.375rem;
    font-weight: 600;
    margin: 0 0 0.5rem;
    color: var(--pid-ink);
}
.community-tile__desc {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    margin: 0;
}

/* ============================================================
   PATTERN: PLAN YOUR TRIP GRID
   ============================================================ */
.visit-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.visit-card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    padding: 1.75rem 1.5rem 3rem;
    text-decoration: none;
    color: var(--pid-ink);
    transition: border-color 0.2s ease, transform 0.3s var(--pid-ease);
}
.visit-card:hover {
    border-color: var(--pid-ink);
    transform: translateY(-2px);
}
.visit-card__eyebrow {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0 0 0.625rem;
}
.visit-card__title {
    font-family: var(--pid-serif);
    font-size: 1.375rem;
    font-weight: 600;
    margin: 0 0 0.625rem;
    color: var(--pid-ink);
}
.visit-card__desc {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    margin: 0;
}
.visit-card__arrow {
    position: absolute;
    bottom: 1.25rem;
    right: 1.5rem;
    font-size: 1.25rem;
    color: var(--pid-ink);
    transition: transform 0.2s ease;
}
.visit-card:hover .visit-card__arrow { transform: translateX(3px); }

/* ============================================================
   PATTERN: VOLUNTEER + SPONSOR SPLIT
   ============================================================ */
.volunteer-sponsor-split { padding: 0; }
.split-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
}
.split-panel {
    position: relative;
    display: block;
    min-height: 480px;
    background-size: cover;
    background-position: center;
    text-decoration: none;
    color: var(--pid-canvas);
    overflow: hidden;
}
.split-panel::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(13, 11, 20, 0.35) 0%, rgba(13, 11, 20, 0.85) 100%);
    transition: background 0.3s ease;
}
.split-panel:hover::before {
    background: linear-gradient(180deg, rgba(13, 11, 20, 0.45) 0%, rgba(13, 11, 20, 0.92) 100%);
}
.split-panel__inner {
    position: absolute;
    inset: auto 0 0 0;
    padding: clamp(2rem, 4vw, 3rem);
    color: var(--pid-canvas);
}
.split-panel__inner .eyebrow { color: rgba(255, 255, 255, 0.8); }
.split-panel__inner h3 {
    font-family: var(--pid-serif);
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 600;
    color: var(--pid-canvas);
    margin: 0 0 0.75rem;
    line-height: 1.1;
}
.split-panel__inner p {
    color: rgba(255, 255, 255, 0.88);
    font-size: 1rem;
    line-height: 1.7;
    margin: 0 0 1.25rem;
    max-width: 44ch;
    text-wrap: pretty;
}
.split-panel__cta {
    display: inline-block;
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-canvas);
    border-bottom: 1px solid var(--pid-canvas);
    padding-bottom: 2px;
    transition: color 0.2s ease, border-color 0.2s ease;
}
.split-panel:hover .split-panel__cta { color: var(--pid-magenta); border-color: var(--pid-magenta); }

/* ============================================================
   PATTERN: NEWSLETTER CALLOUT
   ============================================================ */
.newsletter-callout__inner {
    max-width: 640px;
    margin-inline: auto;
    text-align: center;
}
.newsletter-form {
    display: flex;
    gap: 0.5rem;
    max-width: 480px;
    margin: 0 auto;
    border: 1px solid var(--pid-ink);
    background: var(--pid-canvas);
    padding: 0.375rem;
}
.newsletter-form__input {
    flex: 1;
    border: 0;
    outline: 0;
    background: transparent;
    padding: 0.75rem 0.75rem;
    font-family: var(--pid-sans);
    font-size: 0.9375rem;
    color: var(--pid-ink);
}
.newsletter-form__input::placeholder { color: var(--pid-ink-muted); }
.newsletter-form__submit {
    background: var(--pid-ink);
    color: var(--pid-canvas);
    border: 0;
    padding: 0.75rem 1.25rem;
    font-family: var(--pid-sans);
    font-weight: 600;
    font-size: 0.875rem;
    cursor: pointer;
    transition: background 0.2s ease;
}
.newsletter-form__submit:hover { background: var(--pid-purple); }
.screen-reader-text {
    position: absolute !important;
    width: 1px; height: 1px;
    padding: 0; margin: -1px; overflow: hidden;
    clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}

/* ============================================================
   NATIVE WP SEARCH BLOCK, editorial style
   ============================================================ */
.wp-block-search.pid-search-form .wp-block-search__inside-wrapper,
.wp-block-search .wp-block-search__inside-wrapper {
    border: 1px solid var(--pid-ink);
    padding: 0.375rem;
    background: var(--pid-canvas);
    max-width: 520px;
    border-radius: 2px;
}
.wp-block-search .wp-block-search__input {
    border: 0;
    outline: 0;
    padding: 0.75rem;
    font-family: var(--pid-sans);
    font-size: 0.9375rem;
    background: transparent;
    color: var(--pid-ink);
}
.wp-block-search .wp-block-search__input::placeholder { color: var(--pid-ink-muted); }
.wp-block-search .wp-block-search__button {
    background: var(--pid-ink);
    color: var(--pid-canvas);
    border: 0;
    padding: 0.75rem 1.25rem;
    font-family: var(--pid-sans);
    font-weight: 600;
    font-size: 0.875rem;
    cursor: pointer;
    border-radius: 2px;
    transition: background 0.2s ease;
}
.wp-block-search .wp-block-search__button:hover { background: var(--pid-purple); }

/* ============================================================
   404 PAGE
   ============================================================ */
.pid-404__inner {
    max-width: 720px;
    margin-inline: auto;
    padding-inline: 1.25rem;
    text-align: left;
}

/* ============================================================
   QUERY PAGINATION
   ============================================================ */
.wp-block-query .wp-block-query-pagination {
    border-top: 1px solid var(--pid-rule);
    padding-top: 1.5rem;
    margin-top: 2rem;
}
.wp-block-query-pagination a,
.wp-block-query-pagination .wp-block-query-pagination-numbers {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pid-ink);
}
.wp-block-query-pagination a:hover { color: var(--pid-purple); }
.wp-block-query-pagination-numbers .page-numbers.current {
    font-weight: 600;
    border-bottom: 1px solid var(--pid-ink);
    padding-bottom: 2px;
}

/* ============================================================
   PATTERN: ABOUT, VALUES GRID
   ============================================================ */
.values-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem 3rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.value-card {
    padding: 1.75rem 0;
    border-top: 1px solid var(--pid-rule);
}
.value-card__number {
    display: block;
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    color: var(--pid-ink-muted);
    margin-bottom: 0.75rem;
}
.value-card__title {
    font-family: var(--pid-serif);
    font-size: 1.75rem;
    font-weight: 600;
    margin: 0 0 0.75rem;
    color: var(--pid-ink);
}
.value-card__body {
    font-size: 1rem;
    color: var(--pid-ink-muted);
    line-height: 1.7;
    margin: 0;
    max-width: 52ch;
    text-wrap: pretty;
}

/* ============================================================
   PATTERN: HISTORY TIMELINE
   ============================================================ */
.pid-timeline {
    list-style: none;
    padding: 0;
    margin: 0 auto;
    max-width: 780px;
    position: relative;
}
.pid-timeline::before {
    content: "";
    position: absolute;
    left: 10px;
    top: 8px;
    bottom: 8px;
    width: 1px;
    background: var(--pid-rule);
}
.pid-timeline__item {
    position: relative;
    padding: 0 0 2.5rem 2.5rem;
}
.pid-timeline__item:last-child { padding-bottom: 0; }
.pid-timeline__marker {
    position: absolute;
    left: 0;
    top: 10px;
    width: 21px;
    height: 21px;
    border-radius: 50%;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-ink);
}
.pid-timeline__marker::before {
    content: "";
    position: absolute;
    inset: 4px;
    border-radius: 50%;
    background: var(--pid-purple);
}
.pid-timeline__year {
    display: inline-block;
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    color: var(--pid-ink-muted);
    margin-bottom: 0.375rem;
}
.pid-timeline__title {
    font-family: var(--pid-serif);
    font-size: 1.5rem;
    font-weight: 600;
    margin: 0 0 0.5rem;
    color: var(--pid-ink);
}
.pid-timeline__text {
    font-size: 1rem;
    color: var(--pid-ink-muted);
    line-height: 1.7;
    margin: 0;
    max-width: 60ch;
    text-wrap: pretty;
}

/* ============================================================
   PATTERN: BOARD & STAFF GRID
   ============================================================ */
.board-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem 1.75rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.board-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 0;
}
.board-card__photo {
    width: 100%;
    aspect-ratio: 1;
    background: var(--pid-canvas-warm);
    border: 1px solid var(--pid-rule);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
}
.board-card__initials {
    font-family: var(--pid-serif);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 600;
    color: var(--pid-ink-muted);
}
.board-card__body { width: 100%; }
.board-card__name {
    font-family: var(--pid-serif);
    font-size: 1.125rem;
    font-weight: 600;
    margin: 0 0 0.125rem;
    color: var(--pid-ink);
}
.board-card__role {
    font-size: 0.9375rem;
    line-height: 1.5;
    color: var(--pid-ink);
    margin: 0 0 0.375rem;
}
.board-card__meta {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0;
}

/* ============================================================
   PATTERN: TRANSPARENCY BREAKDOWN
   ============================================================ */
.transparency-breakdown {
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.breakdown-bar {
    display: flex;
    width: 100%;
    height: 48px;
    border: 1px solid var(--pid-ink);
    margin-bottom: 2rem;
    overflow: hidden;
}
.breakdown-bar__segment {
    display: block;
    height: 100%;
    transition: filter 0.2s ease;
}
.breakdown-bar__segment--0 { background: var(--pid-ink); }
.breakdown-bar__segment--1 { background: var(--pid-purple); }
.breakdown-bar__segment--2 { background: var(--pid-deep-blue); }
.breakdown-bar__segment--3 { background: var(--pid-magenta); }
.breakdown-bar__segment--4 { background: var(--pid-yellow); }
.breakdown-bar__segment:hover { filter: brightness(1.1); }

.breakdown-legend {
    list-style: none;
    padding: 0;
    margin: 0 0 2rem;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 1.25rem;
}
.breakdown-legend__item {
    display: flex;
    gap: 0.75rem;
}
.breakdown-legend__swatch {
    flex-shrink: 0;
    width: 14px;
    height: 14px;
    margin-top: 4px;
    border: 1px solid var(--pid-ink);
}
.breakdown-legend__swatch--0 { background: var(--pid-ink); }
.breakdown-legend__swatch--1 { background: var(--pid-purple); }
.breakdown-legend__swatch--2 { background: var(--pid-deep-blue); }
.breakdown-legend__swatch--3 { background: var(--pid-magenta); }
.breakdown-legend__swatch--4 { background: var(--pid-yellow); }
.breakdown-legend__body { flex: 1; }
.breakdown-legend__label {
    font-family: var(--pid-sans);
    font-size: 0.875rem;
    font-weight: 600;
    margin: 0;
    color: var(--pid-ink);
}
.breakdown-legend__pct {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    color: var(--pid-ink-muted);
    margin-left: 0.375rem;
    font-weight: 400;
}
.breakdown-legend__note {
    font-size: 0.875rem;
    color: var(--pid-ink-muted);
    line-height: 1.6;
    margin: 0.25rem 0 0;
}
.breakdown-footnote {
    max-width: 64ch;
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    font-style: italic;
    line-height: 1.7;
    margin: 0;
    text-wrap: pretty;
}

/* ============================================================
   PATTERN: DOWNLOAD GRID (990 + ANNUAL REPORTS)
   ============================================================ */
.download-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.download-card {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 1.5rem 1.75rem 3.25rem;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    text-decoration: none;
    color: var(--pid-ink);
    transition: border-color 0.2s ease, transform 0.2s ease;
}
.download-card:hover {
    border-color: var(--pid-ink);
    transform: translateY(-2px);
}
.download-card__year {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    color: var(--pid-ink-muted);
    margin-bottom: 0.5rem;
}
.download-card__label {
    font-family: var(--pid-serif);
    font-size: 1.375rem;
    font-weight: 600;
    margin: 0 0 0.375rem;
    color: var(--pid-ink);
}
.download-card__kind {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0;
}
.download-card__arrow {
    position: absolute;
    bottom: 1.25rem;
    right: 1.75rem;
    font-size: 1.5rem;
    color: var(--pid-ink);
    transition: transform 0.2s ease;
}
.download-card:hover .download-card__arrow { transform: translateY(3px); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
    position: relative;
    background: var(--pid-surface-dark);
    color: rgba(255, 255, 255, 0.7);
    border-top: 4px solid transparent;
    background-image:
        linear-gradient(var(--pid-surface-dark), var(--pid-surface-dark)),
        var(--pid-rainbow);
    background-origin: border-box;
    background-clip: padding-box, border-box;
}
.site-footer .wp-block-heading {
    color: var(--pid-canvas);
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    line-height: 1.5;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-weight: 500;
    margin-bottom: 1rem;
}
.site-footer p {
    color: rgba(255, 255, 255, 0.78);
    line-height: 1.65;
}
.site-footer a { color: rgba(255, 255, 255, 0.78); text-decoration: none; transition: color 0.15s ease; }
.site-footer a:hover { color: var(--pid-canvas); }
.site-footer .footer-link a { color: rgba(255, 255, 255, 0.78); }
.site-footer .footer-legal {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    line-height: 1.6;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.82);
}
.site-footer .footer-land-ack {
    font-style: italic;
    color: rgba(255, 255, 255, 0.82);
    font-size: 0.875rem;
    line-height: 1.7;
    max-width: 620px;
    margin-inline: auto;
    text-align: center;
    text-wrap: pretty;
}
.site-footer .footer-ein {
    color: rgba(255, 255, 255, 0.5);
}
.site-footer .footer-brand a {
    color: rgba(255, 255, 255, 0.7);
    text-decoration: underline;
    text-underline-offset: 0.15em;
}
.site-footer .footer-brand a:hover {
    color: var(--pid-canvas);
}
.site-footer .wp-block-separator {
    background-color: rgba(255, 255, 255, 0.28) !important;
    border-color: rgba(255, 255, 255, 0.28) !important;
    color: rgba(255, 255, 255, 0.28) !important;
    opacity: 1;
}
.site-footer .wp-block-columns {
    gap: clamp(2rem, 4vw, 4rem);
}
@media (max-width: 781px) {
    .site-footer .wp-block-columns {
        gap: 2.5rem;
    }
    .site-footer .footer-brand { margin-bottom: 0; }
}

/* ============================================================
   ANIMATION HELPERS
   ============================================================ */
.animate-on-scroll { opacity: 0; transform: translateY(14px); transition: opacity 0.7s var(--pid-ease), transform 0.7s var(--pid-ease); }
.animate-on-scroll.is-visible { opacity: 1; transform: translateY(0); }

@keyframes fadeUp {
    from { opacity: 0; transform: translateY(14px); }
    to   { opacity: 1; transform: translateY(0); }
}

@keyframes scrollBounce {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(4px); }
}

@keyframes marquee-scroll {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

/* ============================================================
   PAGE FEATURED IMAGE (page.html)
   ============================================================ */
.pid-page-feature {
    margin: 0 !important;
}
.pid-page-feature img {
    width: 100%;
    max-height: 520px;
    object-fit: cover;
    display: block;
}
@media (max-width: 781px) {
    .pid-page-feature img { max-height: 360px; }
}

/* ============================================================
   RESOURCE ORG CARDS (inside community resource pages)
   ============================================================ */
.org-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin: 1.75rem 0 2.5rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.org-card {
    display: flex;
    flex-direction: column;
    padding: 2rem 1.75rem 1.75rem;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-left: 3px solid var(--pid-purple);
    border-radius: 2px;
    transition: transform 0.25s var(--pid-ease), border-color 0.2s ease, box-shadow 0.25s var(--pid-ease);
}
.org-card:hover {
    transform: translateY(-3px);
    border-left-color: var(--pid-magenta);
    box-shadow: 0 18px 40px -26px rgba(13, 13, 13, 0.2);
}
.org-card__name {
    font-family: var(--pid-serif);
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.2;
    margin: 0 0 0.75rem;
    color: var(--pid-ink);
    text-wrap: balance;
}
.org-card__desc {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    line-height: 1.6;
    margin: 0 0 1.25rem;
}
.org-card__link {
    margin-top: auto;
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink);
    text-decoration: none;
    border-bottom: 1px solid var(--pid-ink);
    padding-bottom: 2px;
    align-self: flex-start;
    transition: color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}
.org-card__link:hover {
    color: var(--pid-purple);
    border-color: var(--pid-purple);
}
@media (max-width: 1024px) {
    .org-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .org-grid { grid-template-columns: 1fr; gap: 1rem; }
    .org-card { padding: 1.5rem 1.25rem 1.5rem; }
    .org-card__name { font-size: 1.25rem; }
}

/* ============================================================
   CRISIS CALLOUT (prominent emergency contact box)
   ============================================================ */
.crisis-callout {
    background: var(--pid-ink);
    color: var(--pid-canvas);
    padding: 2rem clamp(1.5rem, 4vw, 2.5rem);
    border-left: 4px solid var(--pid-magenta);
    margin: 2rem 0;
}
.crisis-callout h3 {
    color: var(--pid-canvas);
    font-family: var(--pid-serif);
    font-size: 1.5rem;
    margin: 0 0 0.75rem;
}
.crisis-callout p {
    color: rgba(255, 255, 255, 0.88);
    margin: 0 0 0.625rem;
    font-size: 0.9375rem;
    line-height: 1.65;
}
.crisis-callout strong {
    color: var(--pid-canvas);
    font-family: var(--pid-mono);
    font-size: 1rem;
    letter-spacing: 0.02em;
}
.crisis-callout a {
    color: var(--pid-canvas);
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);
}
.crisis-callout a:hover {
    border-bottom-color: var(--pid-canvas);
}

/* ============================================================
   RESOURCE DIRECTORY INDEX (legacy, formerly used on /community, kept for future reuse)
   ============================================================ */
.resource-index {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2.5rem 2rem;
    margin: 0;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.resource-index__card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-radius: 3px;
    overflow: hidden;
    text-decoration: none;
    color: var(--pid-ink);
    transition: transform 0.35s var(--pid-ease), box-shadow 0.35s var(--pid-ease), border-color 0.25s ease;
}
.resource-index__card::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 3px;
    background: var(--pid-purple);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.4s var(--pid-ease);
}
.resource-index__card:hover {
    transform: translateY(-6px);
    box-shadow: 0 32px 60px -32px rgba(13, 13, 13, 0.32);
    border-color: var(--pid-ink);
}
.resource-index__card:hover::after {
    transform: scaleX(1);
}
.resource-index__image {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    position: relative;
}
.resource-index__image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 60%, rgba(13, 11, 20, 0.08) 100%);
    pointer-events: none;
}
.resource-index__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.9s var(--pid-ease);
}
.resource-index__card:hover .resource-index__image img { transform: scale(1.06); }
.resource-index__body {
    padding: 2.25rem 2rem 2.25rem;
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 0.25rem;
}
.resource-index__eyebrow {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0 0 0.75rem;
}
.resource-index__title {
    font-family: var(--pid-serif);
    font-size: clamp(1.625rem, 2.25vw, 1.875rem);
    font-weight: 600;
    line-height: 1.1;
    letter-spacing: -0.015em;
    color: var(--pid-ink);
    margin: 0 0 0.875rem;
    text-wrap: balance;
}
.resource-index__desc {
    font-size: 1rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    margin: 0 0 1.75rem;
    flex: 1;
}
.resource-index__cta {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink);
    padding: 0;
    align-self: flex-start;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: color 0.2s ease, gap 0.3s var(--pid-ease);
    border: 0;
}
.resource-index__cta::before {
    content: "";
    display: inline-block;
    width: 2rem;
    height: 1px;
    background: currentColor;
    transition: width 0.3s var(--pid-ease);
}
.resource-index__card:hover .resource-index__cta {
    color: var(--pid-purple);
    gap: 0.75rem;
}
.resource-index__card:hover .resource-index__cta::before {
    width: 2.75rem;
}

@media (max-width: 1024px) {
    .resource-index { grid-template-columns: repeat(2, 1fr); gap: 1.5rem 1.25rem; }
}
@media (max-width: 600px) {
    .resource-index { grid-template-columns: 1fr; gap: 1.5rem; }
    .resource-index__body { padding: 1.25rem 1.25rem 1.5rem; }
    .resource-index__title { font-size: 1.375rem; }
}

/* Generous breathing room for the community pages on wide screens */
.pid-community-page .pid-section {
    padding-block: clamp(3.5rem, 7vw, 6.5rem);
}
.pid-community-page .pid-section-head + * {
    margin-top: 1rem;
}
@media (min-width: 1200px) {
    .pid-community-page .pid-section > .pid-container {
        padding-inline: 2rem;
    }
}

/* ============================================================
   /COMMUNITY INDEX, DEDICATED LAYOUT
   ============================================================ */
.pid-section.pid-community-hero {
    padding-block: clamp(4.5rem, 10vw, 9rem);
    position: relative;
}
.pid-community-hero > .pid-container {
    position: relative;
}
.pid-community-hero > .pid-container::before {
    content: "";
    display: block;
    height: 4px;
    width: 96px;
    background: var(--pid-rainbow);
    margin-bottom: 1.5rem;
    border-radius: 2px;
}
.pid-community-hero .pid-community-hero__eyebrow {
    margin: 0 0 1.25rem;
    display: block;
}
.pid-community-hero h1.pid-community-hero__title {
    font-size: clamp(3rem, 9vw, 6.25rem);
    line-height: 0.95;
    letter-spacing: -0.03em;
    margin: 0 0 1.75rem;
    max-width: 16ch;
    text-wrap: balance;
    font-weight: 600;
}
.pid-community-hero p.pid-community-hero__lede {
    font-size: clamp(1.1875rem, 1.8vw, 1.4375rem);
    line-height: 1.55;
    color: var(--pid-ink);
    max-width: 60ch;
    text-wrap: pretty;
    margin: 0;
    font-weight: 400;
    opacity: 0.82;
}

.pid-section.pid-community-main {
    padding-block: clamp(4rem, 9vw, 7.5rem);
}
.pid-community-main > .pid-community-browse {
    margin-bottom: clamp(4rem, 7vw, 6rem);
}
.pid-community-main .pid-section-head {
    margin-bottom: clamp(2.5rem, 4.5vw, 3.5rem);
    padding-bottom: 1.5rem;
}
.pid-community-main .pid-section-head h2 {
    font-size: clamp(2rem, 3.5vw, 2.75rem);
    letter-spacing: -0.02em;
}
.pid-community-main .resource-index {
    margin-block: 0;
}

/* Submission callout card at the bottom */
.pid-community-callout {
    max-width: 720px;
    margin-inline: auto;
    padding: clamp(2.5rem, 5vw, 4rem) clamp(1.75rem, 4vw, 3rem) !important;
    text-align: center;
    background: var(--pid-canvas-warm);
    border: 1px solid var(--pid-rule);
    border-top: 3px solid var(--pid-purple);
    border-radius: 2px;
    transition: border-top-color 0.2s ease;
}
.pid-community-callout:hover {
    border-top-color: var(--pid-magenta);
}
.pid-community-callout .eyebrow {
    margin: 0 auto 0.75rem !important;
    display: block;
}
.pid-community-callout h3 {
    font-family: var(--pid-serif);
    font-size: clamp(1.625rem, 3vw, 2.25rem);
    font-weight: 600;
    line-height: 1.15;
    margin: 0 auto 1rem;
    max-width: 22ch;
    text-wrap: balance;
    color: var(--pid-ink);
}
.pid-community-callout p {
    color: var(--pid-ink-muted);
    font-size: 1rem;
    line-height: 1.7;
    margin: 0 auto 1.75rem;
    max-width: 50ch;
    text-wrap: pretty;
}
.pid-community-callout .wp-block-button__link {
    padding: 1rem 2rem;
    font-size: 0.9375rem;
}

@media (max-width: 781px) {
    .pid-community-hero__title {
        max-width: none;
    }
    .pid-community-callout {
        margin-inline: 0;
    }
}

/* ============================================================
   PLAN YOUR TRIP, TRANSPORTATION GRID
   ============================================================ */
.transit-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.transit-grid--six {
    grid-template-columns: repeat(3, 1fr);
}
.transit-card {
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    padding: 2rem 1.5rem 1.75rem;
    text-align: left;
    transition: transform 0.3s var(--pid-ease), border-color 0.2s ease;
}
.transit-card:hover {
    transform: translateY(-2px);
    border-color: var(--pid-ink);
}
.transit-card__icon {
    display: inline-block;
    font-size: 2rem;
    line-height: 1;
    margin-bottom: 0.875rem;
}
.transit-card__title {
    font-family: var(--pid-serif);
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0 0 0.5rem;
    color: var(--pid-ink);
}
.transit-card__body {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    margin: 0;
}

/* ============================================================
   PLAN YOUR TRIP, HOTEL CARDS (text-based, near the Strip)
   ============================================================ */
.hotel-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.hotel-card {
    display: flex;
    flex-direction: column;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-left: 3px solid var(--pid-purple);
    padding: 2rem 2rem 1.75rem;
    transition: transform 0.25s var(--pid-ease), border-color 0.2s ease, box-shadow 0.25s var(--pid-ease);
}
.hotel-card:hover {
    transform: translateY(-3px);
    border-left-color: var(--pid-magenta);
    box-shadow: 0 18px 40px -26px rgba(13, 13, 13, 0.25);
}
.hotel-card__type {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0 0 0.625rem;
}
.hotel-card__name {
    font-family: var(--pid-serif);
    font-size: clamp(1.5rem, 2.5vw, 1.875rem);
    font-weight: 600;
    line-height: 1.15;
    color: var(--pid-ink);
    margin: 0 0 0.625rem;
    text-wrap: balance;
}
.hotel-card__distance {
    font-family: var(--pid-sans);
    font-size: 0.875rem;
    color: var(--pid-purple);
    font-weight: 500;
    margin: 0 0 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--pid-rule);
}
.hotel-card__body {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    margin: 0 0 1.25rem;
    flex: 1;
}
.hotel-card__address {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.06em;
    color: var(--pid-ink-muted);
    margin: 0 0 1rem;
}
.hotel-card__cta {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pid-ink);
    text-decoration: none;
    border-bottom: 1px solid var(--pid-ink);
    padding-bottom: 2px;
    align-self: flex-start;
    transition: color 0.2s ease, border-color 0.2s ease;
}
.hotel-card__cta:hover {
    color: var(--pid-purple);
    border-color: var(--pid-purple);
}
@media (max-width: 900px) {
    .hotel-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   PLAN YOUR TRIP, ACCESSIBILITY HIGHLIGHTS
   ============================================================ */
.access-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.access-card {
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    padding: 1.5rem 1.5rem 1.75rem;
    border-left: 3px solid var(--pid-deep-blue);
    transition: transform 0.2s ease, border-color 0.2s ease;
}
.access-card:hover {
    transform: translateY(-2px);
    border-left-color: var(--pid-magenta);
}
.access-card__icon {
    display: inline-block;
    font-size: 1.5rem;
    line-height: 1;
    margin-bottom: 0.625rem;
}
.access-card__title {
    font-family: var(--pid-serif);
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--pid-ink);
    margin: 0 0 0.375rem;
}
.access-card__body {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    margin: 0;
}

@media (max-width: 1024px) {
    .transit-grid,
    .transit-grid--six { grid-template-columns: repeat(2, 1fr); }
    .access-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .transit-grid,
    .transit-grid--six { grid-template-columns: 1fr; }
    .access-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   GET INVOLVED, PRINCIPLES GRID
   ============================================================ */
.principles-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.principle-card {
    padding: 1.75rem 1.5rem 1.5rem;
    border-top: 1px solid var(--pid-rule);
    transition: border-color 0.2s ease;
}
.principle-card:hover { border-top-color: var(--pid-ink); }
.principle-card__number {
    display: inline-block;
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.12em;
    color: var(--pid-ink-muted);
    margin-bottom: 0.875rem;
}
.principle-card__title {
    font-family: var(--pid-serif);
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.15;
    color: var(--pid-ink);
    margin: 0 0 0.625rem;
    text-wrap: balance;
}
.principle-card__body {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    margin: 0;
}
@media (max-width: 1024px) {
    .principles-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
}
@media (max-width: 600px) {
    .principles-grid { grid-template-columns: 1fr; }
}

/* Sponsor tier "best for" fit line (replaces benefits list for new-org version) */
.sponsor-tier__fit {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0 0 1.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--pid-rule);
}
.sponsor-tier--featured .sponsor-tier__fit {
    color: rgba(255, 255, 255, 0.7);
    border-bottom-color: rgba(255, 255, 255, 0.15);
}

/* ============================================================
   SPONSORS PAGE, 6-TIER GRID + BENEFITS MATRIX
   ============================================================ */
.sponsor-tiers--six {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-bottom: 3.5rem;
}
.sponsor-tiers--six .sponsor-tier__amount {
    font-size: clamp(2rem, 3vw, 2.75rem);
}
.sponsor-tiers--six .sponsor-tier {
    padding: 1.75rem 1.5rem 1.75rem;
}
.sponsor-tiers--six .sponsor-tier--featured {
    transform: none;
}
.sponsor-tiers--six .sponsor-tier--featured:hover {
    transform: translateY(-4px);
}
@media (max-width: 1100px) {
    .sponsor-tiers--six { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
    .sponsor-tiers--six { grid-template-columns: 1fr; }
}

.sponsor-matrix-wrap {
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
    margin-top: 3rem;
}
.sponsor-matrix-label {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0 0 1rem;
    text-align: center;
}
.sponsor-matrix-scroll {
    overflow-x: auto;
    border: 1px solid var(--pid-rule);
    border-radius: 3px;
}
.sponsor-matrix {
    width: 100%;
    border-collapse: collapse;
    min-width: 720px;
}
.sponsor-matrix thead th {
    font-family: var(--pid-serif);
    font-size: 1rem;
    font-weight: 600;
    color: var(--pid-ink);
    background: var(--pid-canvas-warm);
    padding: 1.25rem 0.75rem 0.625rem;
    text-align: center;
    border-bottom: 1px solid var(--pid-rule);
}
.sponsor-matrix thead .sponsor-matrix__amount-row td {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    color: var(--pid-ink-muted);
    padding: 0 0.75rem 1rem;
    text-align: center;
    background: var(--pid-canvas-warm);
    border-bottom: 1px solid var(--pid-rule);
    font-weight: 500;
}
.sponsor-matrix .sponsor-matrix__benefit-col {
    text-align: left !important;
    min-width: 240px;
    padding-left: 1.5rem !important;
}
.sponsor-matrix tbody th {
    font-family: var(--pid-sans);
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--pid-ink);
    text-align: left;
    padding: 0.9rem 1.5rem;
    border-bottom: 1px solid var(--pid-rule);
    background: var(--pid-canvas);
}
.sponsor-matrix tbody tr:last-child th,
.sponsor-matrix tbody tr:last-child td {
    border-bottom: 0;
}
.sponsor-matrix tbody td {
    padding: 0.9rem 0.75rem;
    text-align: center;
    color: var(--pid-ink-muted);
    font-size: 1rem;
    border-bottom: 1px solid var(--pid-rule);
    background: var(--pid-canvas);
}
.sponsor-matrix tbody td.is-yes {
    color: var(--pid-purple);
    font-size: 1.125rem;
}
.sponsor-matrix tbody td.is-no {
    color: var(--pid-rule);
}
.sponsor-matrix tbody tr:hover th,
.sponsor-matrix tbody tr:hover td {
    background: var(--pid-canvas-warm);
}

/* ============================================================
   SPONSORS PAGE, PRICING TABLES (parade entry + vendor fees)
   ============================================================ */
.pricing-table-wrap {
    max-width: 840px;
    margin-inline: auto;
    width: 100%;
}
.pricing-table {
    width: 100%;
    border-collapse: collapse;
    border: 1px solid var(--pid-rule);
    border-radius: 3px;
    overflow: hidden;
}
.pricing-table thead th {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    background: var(--pid-canvas-warm);
    padding: 1rem 1.5rem;
    text-align: left;
    border-bottom: 1px solid var(--pid-rule);
    font-weight: 500;
}
.pricing-table thead th:not(:first-child) {
    text-align: right;
}
.pricing-table tbody th {
    font-weight: 500;
    color: var(--pid-ink);
    padding: 1.25rem 1.5rem;
    text-align: left;
    background: var(--pid-canvas);
    border-bottom: 1px solid var(--pid-rule);
    vertical-align: top;
}
.pricing-table tbody tr:last-child th,
.pricing-table tbody tr:last-child td {
    border-bottom: 0;
}
.pricing-table__title {
    display: block;
    font-family: var(--pid-serif);
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--pid-ink);
    line-height: 1.2;
    margin-bottom: 0.25rem;
}
.pricing-table__note {
    display: block;
    font-family: var(--pid-sans);
    font-size: 0.8125rem;
    color: var(--pid-ink-muted);
    font-weight: 400;
    line-height: 1.4;
}
.pricing-table tbody td.pricing-table__price {
    padding: 1.25rem 1.5rem;
    text-align: right;
    font-family: var(--pid-serif);
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--pid-ink);
    background: var(--pid-canvas);
    border-bottom: 1px solid var(--pid-rule);
    vertical-align: middle;
}
.pricing-table__footnote {
    font-family: var(--pid-sans);
    font-size: 0.8125rem;
    font-style: italic;
    color: var(--pid-ink-muted);
    line-height: 1.6;
    margin: 1rem 0 0;
    text-align: center;
}
@media (max-width: 600px) {
    .pricing-table thead { display: none; }
    .pricing-table tbody th,
    .pricing-table tbody td { display: block; text-align: left; padding: 0.75rem 1.25rem; }
    .pricing-table tbody td.pricing-table__price { text-align: left; padding-top: 0; padding-bottom: 1.25rem; }
    .pricing-table__title { font-size: 1rem; }
}

/* ============================================================
   SPONSORS PAGE, LOGO WALL (past sponsors)
   ============================================================ */
.sponsor-logo-wall {
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.sponsor-logo-wall__tier {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0 0 1rem;
    text-align: center;
    padding-top: 1rem;
}
.sponsor-logo-wall__tier:not(:first-child) {
    padding-top: 2.5rem;
    border-top: 1px solid var(--pid-rule);
    margin-top: 2.5rem;
}
.sponsor-logo-wall__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1.25rem;
}
.sponsor-logo-wall__slot {
    aspect-ratio: 3 / 2;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--pid-canvas);
    border: 1px dashed var(--pid-rule);
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    border-radius: 3px;
}

/* ============================================================
   SPONSORS WALL (live CPT, /sponsors page)
   ============================================================ */
.sponsors-wall {
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: clamp(2.5rem, 5vw, 4.5rem);
}
.sponsors-wall--empty {
    text-align: center;
    padding: 3rem 1.5rem;
    color: var(--pid-ink-muted);
    font-style: italic;
    border: 1px dashed var(--pid-rule);
    border-radius: 3px;
}
.sponsors-wall__tier-section {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}
.sponsors-wall__tier-head {
    padding-bottom: 1rem;
    margin-bottom: 0.25rem;
    border-bottom: 1px solid var(--pid-rule);
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.sponsors-wall__tier-label {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    font-weight: 500;
    margin: 0;
}
.sponsors-wall__tier-amount {
    color: var(--pid-ink);
    opacity: 0.55;
    font-weight: 500;
}
.sponsors-wall__tier-desc {
    font-family: var(--pid-sans);
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    margin: 0;
    max-width: 60ch;
    line-height: 1.5;
}
.sponsors-wall__tier-section--presenting .sponsors-wall__tier-label {
    color: var(--pid-purple);
}
.sponsors-wall__tier-section--presenting .sponsors-wall__tier-amount {
    color: var(--pid-magenta);
    opacity: 1;
}

/* Tier-adaptive card grids (Diamond, Platinum, Gold) */
.sponsors-wall__card-grid {
    display: grid;
    gap: 1.5rem;
}
.sponsors-wall__card-grid--diamond {
    grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
}
.sponsors-wall__card-grid--platinum {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}
.sponsors-wall__card-grid--gold {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.25rem;
}
.sponsors-wall__card-grid--diamond .sponsor-card {
    border-left: 3px solid var(--pid-purple);
}
.sponsors-wall__card-grid--platinum .sponsor-card {
    border-top: 2px solid var(--pid-magenta);
}
.sponsors-wall__card-grid--gold .sponsor-card__logo {
    aspect-ratio: 16 / 9;
    padding: 1.25rem;
}
.sponsors-wall__card-grid--gold .sponsor-card__body {
    padding: 1.25rem 1.25rem 1.5rem;
}
.sponsors-wall__card-grid--gold .sponsor-card__name {
    font-size: 1.125rem;
    margin-bottom: 0.5rem;
}
.sponsors-wall__card-grid--gold .sponsor-card__desc {
    font-size: 0.875rem;
    margin-bottom: 1rem;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
}

/* Silver tier, logo tile grid */
.sponsors-wall__logo-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
}
.sponsors-wall__logo-tile {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.875rem;
    padding: 1.5rem 1rem;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-radius: 3px;
    text-decoration: none;
    color: var(--pid-ink);
    min-height: 140px;
    transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}
.sponsors-wall__logo-tile:hover {
    border-color: var(--pid-ink);
    transform: translateY(-2px);
    box-shadow: 0 16px 32px -20px rgba(13, 13, 13, 0.2);
}
.sponsors-wall__logo-tile-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 56px;
    width: 100%;
}
.sponsors-wall__logo-tile-logo img {
    max-height: 56px;
    max-width: 100%;
    object-fit: contain;
    filter: grayscale(15%);
    transition: filter 0.2s ease;
}
.sponsors-wall__logo-tile:hover .sponsors-wall__logo-tile-logo img {
    filter: grayscale(0%);
}
.sponsors-wall__logo-tile-fallback {
    font-family: var(--pid-serif);
    font-size: 2rem;
    font-weight: 600;
    color: var(--pid-ink-muted);
    opacity: 0.5;
    line-height: 1;
}
.sponsors-wall__logo-tile-name {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-align: center;
    color: var(--pid-ink);
    margin: 0;
    line-height: 1.3;
    text-wrap: balance;
}

/* Featured presenting inside the sponsors wall, single large card */
.sponsor-featured-grid--wall {
    grid-template-columns: 1fr;
    max-width: 100%;
}
.sponsor-featured-grid--wall .sponsor-featured {
    min-height: 380px;
}

/* Inline community-tier marquee variant, lighter, embedded */
.sponsor-marquee--inline {
    padding-block: 0.5rem;
    margin-top: 0.25rem;
}
.sponsor-marquee--inline .sponsor-marquee__item {
    height: 64px;
    min-width: 120px;
    max-width: 180px;
}
.sponsor-marquee--inline .sponsor-marquee__item img {
    max-height: 52px;
}
.sponsor-marquee--inline .sponsor-marquee__name {
    font-size: 1rem;
}

@media (max-width: 700px) {
    .sponsors-wall__card-grid--diamond,
    .sponsors-wall__card-grid--platinum,
    .sponsors-wall__card-grid--gold {
        grid-template-columns: 1fr;
    }
    .sponsors-wall__logo-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Sponsor card, base (used inside card grids) */
.sponsor-card {
    display: flex;
    flex-direction: column;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-radius: 3px;
    overflow: hidden;
    transition: transform 0.3s var(--pid-ease), box-shadow 0.3s var(--pid-ease), border-color 0.2s ease;
}
.sponsor-card:hover {
    transform: translateY(-3px);
    border-color: var(--pid-ink);
    box-shadow: 0 24px 48px -28px rgba(13, 13, 13, 0.25);
}
.sponsor-card__logo {
    aspect-ratio: 16 / 9;
    background: var(--pid-canvas-warm);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    border-bottom: 1px solid var(--pid-rule);
}
.sponsor-card__logo img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}
.sponsor-card__logo-fallback {
    font-family: var(--pid-serif);
    font-size: clamp(2.5rem, 5vw, 3.5rem);
    font-weight: 600;
    color: var(--pid-ink-muted);
    opacity: 0.4;
}
.sponsor-card__body {
    padding: 1.5rem 1.5rem 1.75rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.sponsor-card__tier {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0 0 0.5rem;
}
.sponsor-card__name {
    font-family: var(--pid-serif);
    font-size: 1.375rem;
    font-weight: 600;
    line-height: 1.2;
    color: var(--pid-ink);
    margin: 0 0 0.375rem;
    text-wrap: balance;
}
.sponsor-card__tagline {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pid-magenta);
    font-weight: 600;
    margin: 0 0 0.75rem;
    line-height: 1.4;
}
.sponsor-card__desc {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    margin: 0 0 1.25rem;
    flex: 1;
}
.sponsor-card__cta {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink);
    text-decoration: none;
    border-bottom: 1px solid var(--pid-ink);
    padding-bottom: 2px;
    align-self: flex-start;
    transition: color 0.2s ease, border-color 0.2s ease;
}
.sponsor-card__cta:hover {
    color: var(--pid-purple);
    border-color: var(--pid-purple);
}

/* ============================================================
   HOMEPAGE FEATURED PRESENTING SPONSOR CARD
   (also used inside sponsors wall via .sponsor-featured-grid--wall)
   ============================================================ */
.sponsor-featured-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(420px, 1fr));
    gap: 1.75rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.sponsor-featured {
    position: relative;
    background: var(--pid-ink);
    color: var(--pid-canvas);
    padding: clamp(2rem, 4vw, 3.5rem);
    border-radius: 4px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-height: 420px;
}
.sponsor-featured::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 85% 15%, rgba(126, 0, 254, 0.25), transparent 55%);
    pointer-events: none;
}
.sponsor-featured > * { position: relative; z-index: 1; }
.sponsor-featured__eyebrow {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--pid-magenta);
    margin: 0 0 1.5rem;
}
.sponsor-featured__logo {
    margin-bottom: 1.75rem;
    max-height: 140px;
    display: flex;
    align-items: center;
}
.sponsor-featured__logo img {
    max-height: 140px;
    max-width: 100%;
    object-fit: contain;
    filter: brightness(1.05) contrast(1.05);
}
.sponsor-featured__logo-fallback {
    font-family: var(--pid-serif);
    font-size: 5rem;
    font-weight: 600;
    color: var(--pid-canvas);
    opacity: 0.85;
    line-height: 1;
}
.sponsor-featured__name {
    font-family: var(--pid-serif);
    font-size: clamp(2rem, 3.5vw, 2.75rem);
    font-weight: 600;
    line-height: 1.1;
    color: var(--pid-canvas);
    margin: 0 0 0.5rem;
    text-wrap: balance;
}
.sponsor-featured__tagline {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-magenta);
    font-weight: 600;
    margin: 0 0 1.25rem;
    line-height: 1.4;
}
.sponsor-featured__desc {
    color: rgba(255, 255, 255, 0.85);
    font-size: 1.0625rem;
    line-height: 1.7;
    margin: 0 0 1.75rem;
    max-width: 48ch;
    flex: 1;
}
.sponsor-featured__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    font-family: var(--pid-mono);
    font-size: 0.8125rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-canvas);
    background: transparent;
    border: 1px solid var(--pid-canvas);
    padding: 0.9rem 1.5rem;
    border-radius: 2px;
    text-decoration: none;
    align-self: flex-start;
    transition: background 0.2s ease, color 0.2s ease;
}
.sponsor-featured__cta:hover {
    background: var(--pid-magenta);
    color: var(--pid-canvas);
    border-color: var(--pid-magenta);
}

/* Empty state, "Be our first Presenting sponsor" */
.sponsor-featured--empty {
    background: var(--pid-canvas);
    color: var(--pid-ink);
    border: 1px solid var(--pid-rule);
    border-left: 3px solid var(--pid-magenta);
    min-height: auto;
}
.sponsor-featured--empty::before { display: none; }
.sponsor-featured--empty .sponsor-featured__eyebrow { color: var(--pid-magenta); }
.sponsor-featured--empty .sponsor-featured__name { color: var(--pid-ink); }
.sponsor-featured--empty .sponsor-featured__desc { color: var(--pid-ink-muted); }
.sponsor-featured--empty .sponsor-featured__cta {
    color: var(--pid-ink);
    border-color: var(--pid-ink);
}
.sponsor-featured--empty .sponsor-featured__cta:hover {
    background: var(--pid-ink);
    color: var(--pid-canvas);
}

@media (max-width: 600px) {
    .sponsor-featured-grid { grid-template-columns: 1fr; }
    .sponsor-featured { min-height: auto; }
}

/* ============================================================
   SPONSORS MARQUEE (homepage, community tier carousel)
   ============================================================ */
.pid-section--marquee {
    padding-block: clamp(3rem, 6vw, 5rem) !important;
}
.sponsor-marquee {
    width: 100%;
    overflow: hidden;
    position: relative;
    padding-block: 1rem;
    -webkit-mask-image: linear-gradient(90deg, transparent 0, black 5%, black 95%, transparent 100%);
            mask-image: linear-gradient(90deg, transparent 0, black 5%, black 95%, transparent 100%);
}
.sponsor-marquee--empty {
    text-align: center;
    padding: 2rem 1rem;
    color: var(--pid-ink-muted);
    font-style: italic;
    border: 1px dashed var(--pid-rule);
    border-radius: 3px;
    max-width: 640px;
    margin-inline: auto;
}
.sponsor-marquee__track {
    display: flex;
    align-items: center;
    gap: clamp(2.5rem, 5vw, 5rem);
    animation: marquee-scroll 45s linear infinite;
    width: max-content;
}
.sponsor-marquee:hover .sponsor-marquee__track {
    animation-play-state: paused;
}
.sponsor-marquee__clone {
    display: flex;
    align-items: center;
    gap: clamp(2.5rem, 5vw, 5rem);
}
.sponsor-marquee__item {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 80px;
    min-width: 140px;
    max-width: 220px;
    padding: 0 1rem;
    opacity: 0.85;
    transition: opacity 0.2s ease, transform 0.2s ease;
}
.sponsor-marquee__item:hover {
    opacity: 1;
    transform: scale(1.03);
}
.sponsor-marquee__item a {
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    height: 100%;
    width: 100%;
}
.sponsor-marquee__item img {
    max-height: 70px;
    max-width: 100%;
    object-fit: contain;
    filter: grayscale(20%);
    transition: filter 0.2s ease;
}
.sponsor-marquee__item:hover img {
    filter: grayscale(0%);
}
.sponsor-marquee__name {
    font-family: var(--pid-serif);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--pid-ink);
    line-height: 1.2;
    white-space: nowrap;
}

@media (prefers-reduced-motion: reduce) {
    .sponsor-marquee__track {
        animation: none;
        flex-wrap: wrap;
        justify-content: center;
    }
    .sponsor-marquee__clone { display: none; }
}

/* ============================================================
   PARADE PAGE, DETAILS GRID
   ============================================================ */
.parade-details {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    max-width: var(--pid-wide);
    margin: 0 auto;
    padding: 0;
}
.parade-details__item {
    padding: 2rem 1.5rem 1.75rem;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-top: 3px solid var(--pid-purple);
    border-radius: 3px;
    margin: 0;
    transition: transform 0.2s ease, border-top-color 0.2s ease;
}
.parade-details__item:hover {
    transform: translateY(-3px);
    border-top-color: var(--pid-magenta);
}
.parade-details__label {
    display: block;
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0 0 0.75rem;
    font-weight: 500;
}
.parade-details__value {
    display: block;
    font-family: var(--pid-serif);
    font-size: clamp(1.25rem, 2vw, 1.5rem);
    font-weight: 600;
    line-height: 1.2;
    color: var(--pid-ink);
    margin: 0 0 0.5rem;
    text-wrap: balance;
}
.parade-details__note {
    display: block;
    font-family: var(--pid-sans);
    font-size: 0.875rem;
    line-height: 1.55;
    color: var(--pid-ink-muted);
    margin: 0;
}
@media (max-width: 1024px) {
    .parade-details { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .parade-details { grid-template-columns: 1fr; gap: 1rem; }
}

/* ============================================================
   PARADE PAGE, ENTRY CARDS (participate section)
   ============================================================ */
.parade-entry-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.75rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.parade-entry-card {
    display: flex;
    flex-direction: column;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-radius: 3px;
    padding: 2.25rem 2rem 2rem;
    transition: transform 0.3s var(--pid-ease), border-color 0.2s ease, box-shadow 0.3s var(--pid-ease);
}
.parade-entry-card:hover {
    transform: translateY(-4px);
    border-color: var(--pid-ink);
    box-shadow: 0 24px 48px -28px rgba(13, 13, 13, 0.3);
}
.parade-entry-card__title {
    font-family: var(--pid-serif);
    font-size: clamp(1.5rem, 2.5vw, 1.875rem);
    font-weight: 600;
    line-height: 1.15;
    color: var(--pid-ink);
    margin: 0 0 0.875rem;
    text-wrap: balance;
}
.parade-entry-card__desc {
    font-size: 0.9375rem;
    line-height: 1.65;
    color: var(--pid-ink-muted);
    margin: 0 0 1.5rem;
    flex: 1;
}
.parade-entry-card__prices {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    padding: 1.25rem 0;
    border-top: 1px solid var(--pid-rule);
    border-bottom: 1px solid var(--pid-rule);
    margin-bottom: 1rem;
}
.parade-entry-card__price {
    display: flex;
    flex-direction: column;
    text-align: center;
}
.parade-entry-card__price:first-child {
    border-right: 1px solid var(--pid-rule);
}
.parade-entry-card__price-label {
    font-family: var(--pid-mono);
    font-size: 0.625rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin-bottom: 0.375rem;
}
.parade-entry-card__price-value {
    font-family: var(--pid-serif);
    font-size: clamp(1.75rem, 3vw, 2.25rem);
    font-weight: 600;
    color: var(--pid-ink);
    line-height: 1;
}
.parade-entry-card__note {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.06em;
    color: var(--pid-ink-muted);
    margin: 0;
    font-style: italic;
    text-align: center;
}
@media (max-width: 900px) {
    .parade-entry-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   PARADE PAGE, TIPS GRID (watch section)
   ============================================================ */
.parade-tips-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.parade-tip-card {
    padding: 1.75rem 1.5rem 1.5rem;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-left: 3px solid var(--pid-deep-blue);
    border-radius: 2px;
    transition: transform 0.25s var(--pid-ease), border-left-color 0.2s ease;
}
.parade-tip-card:hover {
    transform: translateY(-2px);
    border-left-color: var(--pid-magenta);
}
.parade-tip-card__icon {
    display: inline-block;
    font-size: 1.75rem;
    line-height: 1;
    margin-bottom: 0.75rem;
}
.parade-tip-card__title {
    font-family: var(--pid-serif);
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1.2;
    color: var(--pid-ink);
    margin: 0 0 0.5rem;
}
.parade-tip-card__body {
    font-size: 0.9375rem;
    line-height: 1.65;
    color: var(--pid-ink-muted);
    margin: 0;
}
@media (max-width: 1024px) {
    .parade-tips-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .parade-tips-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   PARADE PAGE, AROUND THE PARADE GRID
   ============================================================ */
.parade-around-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.75rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.parade-around-card {
    display: flex;
    flex-direction: column;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-radius: 3px;
    overflow: hidden;
    text-decoration: none;
    color: var(--pid-ink);
    transition: transform 0.35s var(--pid-ease), box-shadow 0.35s var(--pid-ease), border-color 0.25s ease;
    position: relative;
}
.parade-around-card::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 3px;
    background: var(--pid-purple);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.4s var(--pid-ease);
}
.parade-around-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 28px 52px -30px rgba(13, 13, 13, 0.28);
    border-color: var(--pid-ink);
}
.parade-around-card:hover::after {
    transform: scaleX(1);
}
.parade-around-card__image {
    aspect-ratio: 16 / 9;
    background-size: cover;
    background-position: center;
    position: relative;
}
.parade-around-card__image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(13, 11, 20, 0.08) 100%);
}
.parade-around-card__body {
    padding: 2rem 2rem 2rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.parade-around-card__eyebrow {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0 0 0.75rem;
}
.parade-around-card__title {
    font-family: var(--pid-serif);
    font-size: clamp(1.625rem, 2.5vw, 2rem);
    font-weight: 600;
    line-height: 1.1;
    letter-spacing: -0.015em;
    color: var(--pid-ink);
    margin: 0 0 0.875rem;
    text-wrap: balance;
}
.parade-around-card__desc {
    font-size: 1rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    margin: 0 0 1.75rem;
    flex: 1;
}
.parade-around-card__cta {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink);
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: color 0.2s ease, gap 0.3s var(--pid-ease);
    align-self: flex-start;
}
.parade-around-card__cta::before {
    content: "";
    display: inline-block;
    width: 2rem;
    height: 1px;
    background: currentColor;
    transition: width 0.3s var(--pid-ease);
}
.parade-around-card:hover .parade-around-card__cta {
    color: var(--pid-purple);
    gap: 0.75rem;
}
.parade-around-card:hover .parade-around-card__cta::before {
    width: 2.75rem;
}

@media (max-width: 900px) {
    .parade-around-grid { grid-template-columns: 1fr; gap: 1.25rem; }
    .parade-around-card__body { padding: 1.75rem 1.5rem; }
}

/* Sponsor strip section variant for the parade page, use canvas instead of warm */
.parade-sponsors-strip {
    background: var(--pid-canvas) !important;
    border-top: 1px solid var(--pid-rule);
    border-bottom: 1px solid var(--pid-rule);
    padding-block: clamp(3rem, 6vw, 5rem) !important;
}
.parade-sponsors-strip__grid {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: clamp(1.5rem, 3vw, 3rem);
    max-width: 960px;
    margin: 0 auto;
}
.parade-sponsors-strip__item {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 64px;
}
.parade-sponsors-strip__item img {
    max-height: 64px;
    width: auto;
    object-fit: contain;
    filter: grayscale(100%);
    opacity: 0.75;
    transition: filter 0.2s ease, opacity 0.2s ease;
}
.parade-sponsors-strip__item a:hover img,
.parade-sponsors-strip__item a:focus img {
    filter: none;
    opacity: 1;
}
.parade-sponsors-strip__name {
    font-family: var(--wp--preset--font-family--fraunces);
    font-size: 1.125rem;
    color: var(--pid-ink);
}

/* ============================================================
   CELEBRATION STRIP (cross-nav between celebration pages)
   ============================================================ */
.celebration-strip-section {
    background: var(--pid-ink);
    color: var(--pid-canvas);
    padding-block: clamp(3rem, 6vw, 5rem) !important;
    position: relative;
    overflow: hidden;
}
.celebration-strip-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 20% 30%, rgba(126, 0, 254, 0.2), transparent 60%);
    pointer-events: none;
}
.celebration-strip-section > .pid-container {
    position: relative;
    z-index: 1;
}
.celebration-strip-section .eyebrow {
    color: var(--pid-magenta) !important;
}
.celebration-strip-section .wp-block-heading {
    color: var(--pid-canvas) !important;
}
.celebration-strip {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.celebration-strip__pill {
    display: flex;
    flex-direction: column;
    padding: 1.5rem 1.25rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 3px;
    text-decoration: none;
    color: var(--pid-canvas);
    text-align: center;
    transition: background 0.25s ease, border-color 0.25s ease, transform 0.25s var(--pid-ease);
}
.celebration-strip__pill:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: var(--pid-magenta);
    transform: translateY(-3px);
}
.celebration-strip__title {
    display: block;
    font-family: var(--pid-serif);
    font-size: 1.375rem;
    font-weight: 600;
    line-height: 1.15;
    color: var(--pid-canvas);
    margin-bottom: 0.375rem;
}
.celebration-strip__subtitle {
    display: block;
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.6);
}
.celebration-strip__pill:hover .celebration-strip__subtitle {
    color: var(--pid-magenta);
}
@media (max-width: 900px) {
    .celebration-strip { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
    .celebration-strip { grid-template-columns: 1fr; }
}

/* ============================================================
   PRIDE WEEK, DAY-BY-DAY SCHEDULE
   ============================================================ */
.pride-week-schedule {
    list-style: none;
    padding: 0;
    margin: 0 auto;
    max-width: 920px;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.pride-week-day {
    display: grid;
    grid-template-columns: 180px 1fr;
    gap: 0;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-radius: 3px;
    overflow: hidden;
    transition: transform 0.25s var(--pid-ease), border-color 0.25s ease, box-shadow 0.25s var(--pid-ease);
}
.pride-week-day:hover {
    transform: translateY(-2px);
    border-color: var(--pid-ink);
    box-shadow: 0 18px 36px -24px rgba(13, 13, 13, 0.22);
}
.pride-week-day--linked {
    border-left: 3px solid var(--pid-purple);
}
.pride-week-day--linked:hover {
    border-left-color: var(--pid-magenta);
}
.pride-week-day__meta {
    background: var(--pid-canvas-warm);
    padding: 1.75rem 1.5rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    border-right: 1px solid var(--pid-rule);
}
.pride-week-day__num {
    font-family: var(--pid-mono);
    font-size: 0.625rem;
    letter-spacing: 0.14em;
    color: var(--pid-ink-muted);
    margin-bottom: 0.5rem;
}
.pride-week-day__day {
    font-family: var(--pid-serif);
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1;
    color: var(--pid-ink);
    margin-bottom: 0.25rem;
}
.pride-week-day__date {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    color: var(--pid-ink-muted);
}
.pride-week-day__body {
    padding: 1.75rem 1.75rem 1.75rem;
    display: flex;
    flex-direction: column;
}
.pride-week-day__tag {
    display: inline-block;
    font-family: var(--pid-mono);
    font-size: 0.625rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-purple);
    margin-bottom: 0.5rem;
    align-self: flex-start;
    padding: 0.3rem 0.625rem;
    background: rgba(126, 0, 254, 0.08);
    border-radius: 2px;
}
.pride-week-day__title {
    font-family: var(--pid-serif);
    font-size: 1.375rem;
    font-weight: 600;
    line-height: 1.2;
    color: var(--pid-ink);
    margin: 0 0 0.5rem;
}
.pride-week-day__desc {
    font-size: 0.9375rem;
    line-height: 1.65;
    color: var(--pid-ink-muted);
    margin: 0 0 0.75rem;
}
.pride-week-day__cta {
    align-self: flex-start;
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink);
    text-decoration: none;
    border-bottom: 1px solid var(--pid-ink);
    padding-bottom: 2px;
    transition: color 0.2s ease, border-color 0.2s ease;
}
.pride-week-day__cta:hover {
    color: var(--pid-purple);
    border-color: var(--pid-purple);
}
@media (max-width: 700px) {
    .pride-week-day {
        grid-template-columns: 1fr;
    }
    .pride-week-day__meta {
        border-right: 0;
        border-bottom: 1px solid var(--pid-rule);
        padding: 1.25rem 1.5rem;
    }
    .pride-week-day__body { padding: 1.5rem; }
}

/* Parade day (centerpiece) treatment, magenta rail + bolder */
.pride-week-day--centerpiece {
    border-color: var(--pid-magenta);
    border-left: 3px solid var(--pid-magenta);
    box-shadow: 0 20px 40px -28px rgba(240, 42, 161, 0.4);
}
.pride-week-day--centerpiece .pride-week-day__meta {
    background: var(--pid-ink);
}
.pride-week-day--centerpiece .pride-week-day__num,
.pride-week-day--centerpiece .pride-week-day__date {
    color: rgba(255, 255, 255, 0.7);
}
.pride-week-day--centerpiece .pride-week-day__day {
    color: var(--pid-canvas);
}
.pride-week-day--centerpiece .pride-week-day__tag {
    color: var(--pid-magenta);
    background: rgba(240, 42, 161, 0.1);
}
.pride-week-day--centerpiece .pride-week-day__title {
    color: var(--pid-ink);
}

/* Day with single event + linked category (subtle rail) */
.pride-week-day--linked:not(.pride-week-day--centerpiece) {
    border-left: 3px solid var(--pid-purple);
}

/* Multi-event day, stacked event list */
.pride-week-day__when {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    color: var(--pid-ink);
    margin: 0 0 0.625rem;
    opacity: 0.7;
}
.pride-week-day__events {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.pride-week-day__event {
    margin: 0;
}
.pride-week-day__event-link {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: 0.875rem 1rem;
    background: var(--pid-canvas-warm);
    border: 1px solid var(--pid-rule);
    border-radius: 3px;
    text-decoration: none;
    color: var(--pid-ink);
    transition: border-color 0.2s ease, transform 0.2s ease, background 0.2s ease;
}
.pride-week-day__event-link:hover {
    border-color: var(--pid-ink);
    transform: translateX(2px);
    background: var(--pid-canvas);
}
.pride-week-day__event-main {
    display: flex;
    align-items: baseline;
    gap: 0.875rem;
    flex-wrap: wrap;
}
.pride-week-day__event-time {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.06em;
    color: var(--pid-purple);
    font-weight: 600;
    flex-shrink: 0;
}
.pride-week-day__event-title {
    font-family: var(--pid-serif);
    font-size: 1.0625rem;
    font-weight: 600;
    color: var(--pid-ink);
    line-height: 1.3;
}
.pride-week-day__event-loc {
    font-size: 0.8125rem;
    color: var(--pid-ink-muted);
    font-style: italic;
}

/* Empty state */
.pride-week-schedule-empty {
    max-width: 920px;
    margin: 0 auto;
    padding: 3rem 2rem;
    text-align: center;
    background: var(--pid-canvas-warm);
    border: 1px dashed var(--pid-rule);
    border-radius: 3px;
}
.pride-week-schedule-empty p {
    color: var(--pid-ink-muted);
    font-style: italic;
    margin: 0;
    line-height: 1.6;
}
.pride-week-schedule-empty a {
    color: var(--pid-purple);
    text-decoration: underline;
    text-underline-offset: 2px;
}

/* ============================================================
   VENDORS PAGE, FAQ ACCORDION
   ============================================================ */
.vendor-faq {
    max-width: 860px;
    margin-inline: auto;
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}
.vendor-faq__item {
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-radius: 3px;
    overflow: hidden;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.vendor-faq__item[open] {
    border-color: var(--pid-ink);
    box-shadow: 0 12px 28px -20px rgba(13, 13, 13, 0.2);
}
.vendor-faq__item:hover {
    border-color: var(--pid-ink);
}
.vendor-faq__q {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem;
    padding: 1.5rem 1.75rem;
    cursor: pointer;
    list-style: none;
    user-select: none;
    transition: background 0.15s ease;
}
.vendor-faq__q::-webkit-details-marker { display: none; }
.vendor-faq__q:hover {
    background: var(--pid-canvas-warm);
}
.vendor-faq__q-text {
    font-family: var(--pid-serif);
    font-size: clamp(1.0625rem, 1.5vw, 1.25rem);
    font-weight: 600;
    line-height: 1.3;
    color: var(--pid-ink);
    flex: 1;
    text-wrap: balance;
}
.vendor-faq__icon {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border: 1px solid var(--pid-ink);
    border-radius: 50%;
    font-size: 1.125rem;
    font-weight: 400;
    color: var(--pid-ink);
    transition: transform 0.3s var(--pid-ease), background 0.2s ease, color 0.2s ease;
}
.vendor-faq__item[open] .vendor-faq__icon {
    transform: rotate(45deg);
    background: var(--pid-ink);
    color: var(--pid-canvas);
}
.vendor-faq__a {
    padding: 0 1.75rem 1.75rem;
}
.vendor-faq__a p {
    font-size: 1rem;
    line-height: 1.75;
    color: var(--pid-ink-muted);
    margin: 0;
    max-width: 68ch;
    text-wrap: pretty;
}

.vendors-cta {
    max-width: 720px !important;
    margin-inline: auto;
    text-align: center;
    padding-block: 1.5rem;
}

@media (max-width: 600px) {
    .vendor-faq__q { padding: 1.25rem 1.25rem; }
    .vendor-faq__a { padding: 0 1.25rem 1.5rem; }
    .vendor-faq__q-text { font-size: 1rem; }
}

/* ============================================================
   PID DIALOG (HTML5 <dialog> modal)
   ============================================================ */

/* The dialog element itself, shown full-screen via showModal(). */
.pid-dialog {
    border: 0;
    padding: 0;
    background: transparent;
    box-shadow: none;
    max-width: min(680px, calc(100vw - 2rem));
    width: 100%;
    max-height: calc(100vh - 2rem);
    margin: auto;
    color: var(--pid-ink);
    overscroll-behavior: contain;
}
.pid-dialog:not([open]) {
    display: none;
}
.pid-dialog::backdrop {
    background: rgba(13, 11, 20, 0.82);
    -webkit-backdrop-filter: blur(6px);
            backdrop-filter: blur(6px);
    animation: pid-dialog-fade 0.25s ease-out;
}
.pid-dialog[open] {
    animation: pid-dialog-rise 0.3s var(--pid-ease);
}
@keyframes pid-dialog-fade {
    from { opacity: 0; }
    to   { opacity: 1; }
}
@keyframes pid-dialog-rise {
    from { opacity: 0; transform: translateY(16px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Fallback styling for browsers without native <dialog> support */
.pid-dialog.pid-dialog--fallback {
    position: fixed;
    inset: 0;
    z-index: 10000;
    margin: 0;
    max-width: none;
    max-height: none;
    width: 100vw;
    height: 100vh;
    display: flex !important;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    background: rgba(13, 11, 20, 0.82);
}
.pid-dialog.pid-dialog--fallback .pid-dialog__content {
    max-width: min(680px, 100%);
}

.pid-dialog__content {
    position: relative;
    background: var(--pid-canvas);
    border-radius: 4px;
    padding: clamp(2rem, 5vw, 3.25rem) clamp(1.5rem, 4vw, 3rem);
    max-height: calc(100vh - 2rem);
    overflow-y: auto;
    box-shadow: 0 40px 80px -30px rgba(0, 0, 0, 0.55);
    -webkit-overflow-scrolling: touch;
}

.pid-dialog__close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 44px;
    height: 44px;
    border: 1px solid var(--pid-rule);
    border-radius: 50%;
    background: var(--pid-canvas);
    color: var(--pid-ink);
    font-size: 1.5rem;
    line-height: 1;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
    font-family: var(--pid-sans);
    font-weight: 300;
    padding: 0;
}
.pid-dialog__close:hover,
.pid-dialog__close:focus-visible {
    background: var(--pid-ink);
    color: var(--pid-canvas);
    border-color: var(--pid-ink);
    transform: rotate(90deg);
    outline: 2px solid var(--pid-purple);
    outline-offset: 3px;
}

.pid-dialog__eyebrow {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--pid-purple);
    margin: 0 0 0.875rem;
    padding-right: 3.5rem; /* leave room for the close button */
}
.pid-dialog__title {
    font-family: var(--pid-serif);
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 600;
    line-height: 1.15;
    color: var(--pid-ink);
    margin: 0 0 1.5rem;
    text-wrap: balance;
    padding-right: 3.5rem;
}
.pid-dialog__body {
    margin-bottom: 2rem;
}
.pid-dialog__body p {
    font-size: 1rem;
    line-height: 1.75;
    color: var(--pid-ink-muted);
    margin: 0 0 1.25rem;
    text-wrap: pretty;
}
.pid-dialog__body h3 {
    font-family: var(--pid-serif);
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1.25;
    color: var(--pid-ink);
    margin: 1.75rem 0 0.75rem;
}
.pid-dialog__body ul,
.pid-dialog__body ol {
    margin: 0 0 1.25rem;
    padding-left: 1.5rem;
}
.pid-dialog__body li {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--pid-ink-muted);
    margin-bottom: 0.625rem;
}
.pid-dialog__body li::marker {
    color: var(--pid-purple);
}
.pid-dialog__cta {
    display: block;
    text-align: center;
    font-family: var(--pid-sans);
    font-size: 0.9375rem;
    font-weight: 600;
    text-decoration: none;
    padding: 1rem 1.5rem;
    background: var(--pid-ink);
    color: var(--pid-canvas);
    border: 1px solid var(--pid-ink);
    border-radius: 2px;
    transition: background 0.2s ease, border-color 0.2s ease;
}
.pid-dialog__cta:hover,
.pid-dialog__cta:focus-visible {
    background: var(--pid-purple);
    border-color: var(--pid-purple);
    color: var(--pid-canvas);
    outline: 2px solid var(--pid-purple);
    outline-offset: 2px;
}

/* Trigger button, looks like a regular link in the section head */
.pid-section-link__button {
    background: transparent;
    border: 0;
    padding: 0;
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit;
    letter-spacing: inherit;
    text-transform: inherit;
    color: inherit;
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 0.25em;
    text-decoration-thickness: 1px;
    text-decoration-color: var(--pid-purple);
    transition: color 0.2s ease, text-decoration-color 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
}
.pid-section-link__button:hover,
.pid-section-link__button:focus-visible {
    color: var(--pid-purple);
    text-decoration-color: var(--pid-magenta);
    outline: 2px solid transparent;
}
.pid-section-link__button:focus-visible {
    outline-color: var(--pid-purple);
    outline-offset: 4px;
    border-radius: 2px;
}

/* Lock body scroll when dialog is open (native dialog handles this via top-layer,
   but some browsers benefit from an explicit lock) */
html:has(dialog[open]) {
    overflow: hidden;
}

/* Mobile dialog adjustments */
@media (max-width: 600px) {
    .pid-dialog {
        max-width: calc(100vw - 1rem);
        max-height: calc(100vh - 1rem);
        margin: 0.5rem auto;
    }
    .pid-dialog__content {
        padding: 2rem 1.25rem 1.5rem;
    }
    .pid-dialog__close {
        top: 0.75rem;
        right: 0.75rem;
    }
    .pid-dialog__eyebrow,
    .pid-dialog__title {
        padding-right: 3rem;
    }
    .pid-dialog__title {
        font-size: clamp(1.5rem, 6vw, 2rem);
    }
    .pid-dialog__body h3 {
        font-size: 1.125rem;
    }
    .pid-dialog__body p,
    .pid-dialog__body li {
        font-size: 0.9375rem;
    }
}

/* Reduced motion, disable dialog animations */
@media (prefers-reduced-motion: reduce) {
    .pid-dialog[open],
    .pid-dialog::backdrop {
        animation: none !important;
    }
}

/* ============================================================
   HOMEPAGE SPONSOR TEASER
   ============================================================ */
.sponsor-teaser-grid {
    display: grid;
    grid-template-columns: 1.35fr 1fr;
    gap: 1.5rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.sponsor-teaser-cards-stack {
    display: grid;
    gap: 1.5rem;
    grid-template-rows: 1fr 1fr;
}
.sponsor-teaser-card {
    display: flex;
    flex-direction: column;
    padding: 2rem 1.75rem 2rem;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    border-radius: 3px;
    text-decoration: none;
    color: var(--pid-ink);
    transition: transform 0.3s var(--pid-ease), box-shadow 0.3s var(--pid-ease), border-color 0.2s ease;
}
.sponsor-teaser-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 36px -24px rgba(13, 13, 13, 0.25);
    border-color: var(--pid-ink);
}
.sponsor-teaser-card--featured {
    background: var(--pid-ink);
    color: var(--pid-canvas);
    border-color: var(--pid-ink);
    padding: clamp(2rem, 4vw, 3.5rem);
    justify-content: flex-end;
    min-height: 320px;
}
.sponsor-teaser-card--featured:hover {
    background: var(--pid-surface-dark);
    border-color: var(--pid-ink);
}
.sponsor-teaser-card__eyebrow {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0 0 0.75rem;
}
.sponsor-teaser-card--featured .sponsor-teaser-card__eyebrow {
    color: var(--pid-magenta);
}
.sponsor-teaser-card__title {
    font-family: var(--pid-serif);
    font-size: clamp(1.5rem, 2.5vw, 2rem);
    font-weight: 600;
    line-height: 1.15;
    margin: 0 0 0.75rem;
    color: inherit;
    text-wrap: balance;
}
.sponsor-teaser-card--featured .sponsor-teaser-card__title {
    font-size: clamp(2rem, 3.5vw, 3rem);
    color: var(--pid-canvas);
}
.sponsor-teaser-card__body {
    font-size: 0.9375rem;
    line-height: 1.65;
    color: var(--pid-ink-muted);
    margin: 0 0 1rem;
    flex: 1;
}
.sponsor-teaser-card--featured .sponsor-teaser-card__body {
    color: rgba(255, 255, 255, 0.82);
    font-size: 1rem;
    line-height: 1.7;
}
.sponsor-teaser-card__cta {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-magenta);
    border-bottom: 1px solid var(--pid-magenta);
    padding-bottom: 2px;
    align-self: flex-start;
    transition: border-color 0.2s ease;
}
.sponsor-teaser-card--featured .sponsor-teaser-card__cta {
    color: var(--pid-magenta);
}
@media (max-width: 900px) {
    .sponsor-teaser-grid { grid-template-columns: 1fr; }
    .sponsor-teaser-card--featured { min-height: 260px; }
}

/* ============================================================
   GET INVOLVED, THREE WAYS TO SHOW UP
   ============================================================ */
.three-ways-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.three-ways-card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    overflow: hidden;
    transition: transform 0.3s var(--pid-ease), box-shadow 0.3s var(--pid-ease), border-color 0.2s ease;
}
.three-ways-card:hover {
    transform: translateY(-4px);
    border-color: var(--pid-ink);
    box-shadow: 0 24px 48px -28px rgba(0, 0, 0, 0.3);
}
.three-ways-card__image {
    aspect-ratio: 4 / 3;
    background-size: cover;
    background-position: center;
    position: relative;
}
.three-ways-card__image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(13, 11, 20, 0.1) 0%, rgba(13, 11, 20, 0.45) 100%);
}
.three-ways-card__body {
    padding: 2rem 1.75rem 2rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.three-ways-card__kind {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
    margin: 0 0 0.625rem;
}
.three-ways-card__title {
    font-family: var(--pid-serif);
    font-size: clamp(1.75rem, 2.75vw, 2.25rem);
    font-weight: 600;
    line-height: 1.1;
    margin: 0 0 0.875rem;
    color: var(--pid-ink);
    text-wrap: balance;
}
.three-ways-card__desc {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    margin: 0 0 1.5rem;
    flex: 1;
}
.three-ways-card__cta {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pid-canvas);
    background: var(--pid-ink);
    padding: 0.9rem 1.35rem;
    border: 1px solid var(--pid-ink);
    text-decoration: none;
    border-radius: 2px;
    align-self: flex-start;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}
.three-ways-card:hover .three-ways-card__cta {
    background: var(--pid-purple);
    border-color: var(--pid-purple);
}

/* ============================================================
   GET INVOLVED, VOLUNTEER ROLE CARDS
   ============================================================ */
.role-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.role-card {
    display: flex;
    flex-direction: column;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    padding: 1.75rem 1.5rem 1.5rem;
    transition: transform 0.25s var(--pid-ease), border-color 0.2s ease, box-shadow 0.25s var(--pid-ease);
    position: relative;
}
.role-card::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--pid-magenta);
    transition: background 0.2s ease;
}
.role-card:hover {
    transform: translateY(-3px);
    border-color: var(--pid-ink);
    box-shadow: 0 18px 36px -24px rgba(13, 13, 13, 0.25);
}
.role-card:hover::before { background: var(--pid-purple); }
.role-card__header { margin-bottom: 0.875rem; }
.role-card__commit {
    display: inline-block;
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--pid-ink);
    background: var(--pid-canvas-warm);
    border: 1px solid var(--pid-rule);
    padding: 0.3rem 0.625rem;
    border-radius: 2px;
    margin-bottom: 0.625rem;
}
.role-card__title {
    font-family: var(--pid-serif);
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1.2;
    margin: 0;
    color: var(--pid-ink);
    text-wrap: balance;
}
.role-card__body {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    margin: 0 0 1.25rem;
    flex: 1;
}
.role-card__footer {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    border-top: 1px solid var(--pid-rule);
    padding-top: 0.875rem;
    gap: 0.5rem;
}
.role-card__skills {
    font-family: var(--pid-mono);
    font-size: 0.625rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--pid-ink-muted);
}
.role-card__cta {
    font-family: var(--pid-mono);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pid-ink);
    text-decoration: none;
    border-bottom: 1px solid var(--pid-ink);
    padding-bottom: 2px;
    transition: color 0.2s ease, border-color 0.2s ease;
}
.role-card__cta:hover {
    color: var(--pid-purple);
    border-color: var(--pid-purple);
}

@media (max-width: 1200px) {
    .role-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px) {
    .role-grid { grid-template-columns: repeat(2, 1fr); }
    .three-ways-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
    .role-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   GET INVOLVED, SPONSORSHIP TIERS
   ============================================================ */
.sponsor-tiers {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    max-width: var(--pid-wide);
    margin-inline: auto;
    width: 100%;
}
.sponsor-tier {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--pid-canvas);
    border: 1px solid var(--pid-rule);
    padding: 2.25rem 2rem 2.25rem;
    transition: transform 0.3s var(--pid-ease), border-color 0.2s ease, box-shadow 0.3s var(--pid-ease);
}
.sponsor-tier:hover {
    transform: translateY(-4px);
    border-color: var(--pid-ink);
    box-shadow: 0 24px 48px -28px rgba(0, 0, 0, 0.25);
}
.sponsor-tier--featured {
    background: var(--pid-ink);
    color: var(--pid-canvas);
    border-color: var(--pid-ink);
    transform: translateY(-12px);
}
.sponsor-tier--featured:hover {
    transform: translateY(-16px);
    box-shadow: 0 32px 56px -32px rgba(0, 0, 0, 0.5);
}
.sponsor-tier__badge {
    position: absolute;
    top: -0.75rem;
    left: 50%;
    transform: translateX(-50%);
    background: var(--pid-magenta);
    color: var(--pid-canvas);
    padding: 0.375rem 0.75rem;
    font-family: var(--pid-mono);
    font-size: 0.625rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-weight: 600;
    white-space: nowrap;
    border-radius: 2px;
}
.sponsor-tier__level {
    font-family: var(--pid-mono);
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin: 0 0 0.75rem;
    color: var(--pid-ink-muted);
    font-weight: 500;
}
.sponsor-tier--featured .sponsor-tier__level {
    color: rgba(255, 255, 255, 0.75);
}
.sponsor-tier__amount {
    font-family: var(--pid-serif);
    font-size: clamp(2.5rem, 4vw, 3.5rem);
    font-weight: 600;
    line-height: 1;
    margin: 0 0 1rem;
    color: var(--pid-ink);
}
.sponsor-tier--featured .sponsor-tier__amount {
    color: var(--pid-canvas);
}
.sponsor-tier__summary {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    margin: 0 0 1.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--pid-rule);
    text-wrap: pretty;
}
.sponsor-tier--featured .sponsor-tier__summary {
    color: rgba(255, 255, 255, 0.8);
    border-bottom-color: rgba(255, 255, 255, 0.15);
}
.sponsor-tier__benefits {
    list-style: none;
    padding: 0;
    margin: 0 0 1.75rem;
    flex: 1;
}
.sponsor-tier__benefits li {
    font-size: 0.9375rem;
    color: var(--pid-ink-muted);
    line-height: 1.65;
    padding: 0.55rem 0 0.55rem 1.5rem;
    position: relative;
}
.sponsor-tier__benefits li::before {
    content: "+";
    position: absolute;
    left: 0;
    top: 0.5rem;
    font-family: var(--pid-mono);
    font-weight: 500;
    color: var(--pid-purple);
}
.sponsor-tier--featured .sponsor-tier__benefits li {
    color: rgba(255, 255, 255, 0.85);
}
.sponsor-tier--featured .sponsor-tier__benefits li::before {
    color: var(--pid-magenta);
}
.sponsor-tier__cta {
    display: inline-block;
    font-family: var(--pid-sans);
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    padding: 0.875rem 1.25rem;
    background: var(--pid-ink);
    color: var(--pid-canvas);
    border: 1px solid var(--pid-ink);
    border-radius: 2px;
    text-align: center;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.sponsor-tier__cta:hover {
    background: var(--pid-purple);
    border-color: var(--pid-purple);
}
.sponsor-tier--featured .sponsor-tier__cta {
    background: var(--pid-magenta);
    border-color: var(--pid-magenta);
}
.sponsor-tier--featured .sponsor-tier__cta:hover {
    background: var(--pid-magenta-dark);
    border-color: var(--pid-magenta-dark);
}

@media (max-width: 900px) {
    .sponsor-tiers { grid-template-columns: 1fr; }
    .sponsor-tier--featured { transform: translateY(0); }
    .sponsor-tier--featured:hover { transform: translateY(-3px); }
}

/* ============================================================
   GET INVOLVED, TESTIMONIAL (inherits theme-manifesto)
   ============================================================ */
.get-involved-testimonial blockquote {
    font-size: clamp(1.5rem, 3.5vw, 2.5rem);
    line-height: 1.25;
}

/* ============================================================
   GET INVOLVED, FINAL CTA
   ============================================================ */
.get-involved-final__inner {
    max-width: 720px;
    margin-inline: auto;
    padding-block: 1.5rem;
    text-align: center;
}

/* ============================================================
   EVENT SINGLE, BACK LINK
   ============================================================ */
.event-back-link {
    color: var(--pid-ink);
    text-decoration: none;
    border-bottom: 1px solid var(--pid-ink);
    padding-bottom: 2px;
    transition: color 0.2s ease, border-color 0.2s ease;
}
.event-back-link:hover { color: var(--pid-purple); border-color: var(--pid-purple); }

/* ============================================================
   FOCUS (accessibility)
   ============================================================ */
a:focus-visible,
button:focus-visible,
.wp-block-button__link:focus-visible,
.wp-element-button:focus-visible,
.pid-archive-filter-btn:focus-visible,
.events-view-all-btn:focus-visible {
    outline: 2px solid var(--pid-purple);
    outline-offset: 2px;
    border-radius: 2px;
}
.newsletter-form__input:focus-visible,
.newsletter-form__submit:focus-visible,
.wp-block-search__input:focus-visible,
.wp-block-search__button:focus-visible {
    outline: 2px solid var(--pid-purple);
    outline-offset: 2px;
    border-radius: 2px;
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.001ms !important;
        scroll-behavior: auto !important;
    }
    .hero-entrance, .animate-on-scroll { opacity: 1 !important; transform: none !important; }
    .events-stagger .event-tile { opacity: 1; transform: none; animation: none; }
    .marquee-track { animation: none; }
    .hero-cover .wp-block-cover__image-background,
    .hero-editorial__cover .wp-block-cover__image-background {
        transform: none !important;
        transition: none !important;
    }
}

/* ============================================================
   RESPONSIVE, TABLET (≤1024px)
   ============================================================ */
@media (max-width: 1024px) {
    .events-row { grid-template-columns: repeat(2, 1fr); }
    .pid-archive-grid { grid-template-columns: repeat(2, 1fr); }
    .passes-grid { grid-template-columns: repeat(2, 1fr); }
    .mission-icons-grid { grid-template-columns: repeat(2, 1fr); }
    .support-grid { grid-template-columns: repeat(2, 1fr); }
    .story-grid { grid-template-columns: repeat(2, 1fr); }
    .community-grid { grid-template-columns: repeat(2, 1fr); }
    .visit-grid { grid-template-columns: repeat(2, 1fr); }
    .board-grid { grid-template-columns: repeat(3, 1fr); }
    .download-grid { grid-template-columns: repeat(2, 1fr); }
    .breakdown-legend { grid-template-columns: repeat(2, 1fr); }
}

/* ============================================================
   RESPONSIVE, SMALL TABLET (≤781px)
   ============================================================ */
@media (max-width: 781px) {
    /* ============================================================
       MOBILE OVERLAY NAVIGATION (SF Pride–style accordion)
       Full-screen overlay. Top-level items are bold uppercase sans.
       Submenu parents show a chevron and are click-to-expand. When
       a submenu is open (.pid-submenu-open on the parent <li>), the
       children render in a floating white card with a magenta→purple
       gradient underline on the active parent label.
       ============================================================ */

    /* Hamburger open button, ensure 44x44 tappable target */
    .site-header-wrap .wp-block-navigation__responsive-container-open {
        min-width: 44px !important;
        min-height: 44px !important;
        padding: 0.625rem !important;
        color: var(--pid-ink) !important;
        background: transparent !important;
        border: 0 !important;
    }
    .site-header-wrap .wp-block-navigation__responsive-container-open svg {
        width: 24px;
        height: 24px;
    }

    /* Full-screen overlay background and scroll container */
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open {
        background: var(--pid-canvas) !important;
        padding: 0 !important;
    }
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
        padding: 5rem 1.5rem 8rem !important;
        max-width: 560px;
        margin-inline: auto;
        width: 100%;
        box-sizing: border-box;
    }

    /* Close (X) button, ensure 44x44, visible, in top-right */
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close {
        position: fixed !important;
        top: 1rem !important;
        right: 1rem !important;
        min-width: 44px !important;
        min-height: 44px !important;
        padding: 0.625rem !important;
        color: var(--pid-ink) !important;
        background: var(--pid-canvas-warm) !important;
        border: 1px solid var(--pid-rule) !important;
        border-radius: 50% !important;
        z-index: 10;
    }
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close svg {
        width: 20px;
        height: 20px;
    }

    /* Top-level nav item list */
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
        gap: 0 !important;
        row-gap: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
    }

    /* Each top-level <li>, plain item OR submenu parent */
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container > .wp-block-navigation-item {
        padding: 0 !important;
        margin: 0 !important;
        width: 100%;
        display: block !important;
        position: relative;
    }

    /* Wrap the top-level anchor + chevron as a single row */
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu {
        display: flex !important;
        flex-wrap: wrap !important;
        align-items: center;
    }
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu > .wp-block-navigation-item__content {
        flex: 1 1 auto !important;
        width: auto !important;
    }

    /* Top-level link, BOLD UPPERCASE SANS-SERIF (SF Pride style) */
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container > .wp-block-navigation-item > .wp-block-navigation-item__content {
        display: inline-flex !important;
        align-items: center !important;
        padding: 1.25rem 0 !important;
        font-family: var(--pid-sans) !important;
        font-size: 1.375rem !important;
        font-weight: 700 !important;
        letter-spacing: 0.02em !important;
        text-transform: uppercase !important;
        color: var(--pid-ink) !important;
        min-height: 56px !important;
        line-height: 1.2 !important;
        text-decoration: none !important;
        position: relative;
    }
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container > .wp-block-navigation-item > .wp-block-navigation-item__content:hover,
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container > .wp-block-navigation-item > .wp-block-navigation-item__content:focus-visible {
        color: var(--pid-magenta) !important;
    }

    /* Chevron toggle, now VISIBLE as a tappable expand button */
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu__toggle {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 44px !important;
        min-width: 44px !important;
        height: 56px !important;
        padding: 0 !important;
        margin-left: 0.375rem !important;
        background: transparent !important;
        border: 0 !important;
        color: var(--pid-ink) !important;
        cursor: pointer;
        transition: transform 0.25s var(--pid-ease), color 0.2s ease;
    }
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu__toggle svg {
        width: 14px !important;
        height: 14px !important;
        fill: currentColor !important;
    }
    /* Rotate chevron when this submenu is open */
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu.pid-submenu-open > .wp-block-navigation-submenu__toggle {
        transform: rotate(180deg);
        color: var(--pid-magenta) !important;
    }
    /* Recolor the parent label when its submenu is open */
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu.pid-submenu-open > .wp-block-navigation-item__content {
        color: var(--pid-magenta) !important;
    }
    /* Gradient underline beneath the entire parent row when open */
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu.pid-submenu-open::after {
        content: "";
        display: block;
        width: 100%;
        height: 2px;
        margin-top: -2px;
        background: linear-gradient(90deg, var(--pid-magenta) 0%, var(--pid-purple) 100%);
        border-radius: 1px;
    }

    /* Thin rule between top-level items (non-open state) */
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container > .wp-block-navigation-item:not(.pid-submenu-open)::after {
        content: "";
        display: block;
        height: 1px;
        background: var(--pid-rule);
        width: 100%;
    }
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container > .wp-block-navigation-item:last-child::after {
        display: none !important;
    }

    /* Submenu container, HIDDEN by default, expanded as floating white card
       when .pid-submenu-open is on the parent <li> */
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container {
        display: none !important;
        position: static !important;
        width: 100% !important;
        min-width: 0 !important;
        margin: 0 !important;
        padding: 0 !important;
        flex-basis: 100%;
        opacity: 0;
        transform: translateY(-4px);
        transition: opacity 0.25s var(--pid-ease), transform 0.25s var(--pid-ease);
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
    }
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu.pid-submenu-open > .wp-block-navigation__submenu-container {
        display: flex !important;
        flex-direction: column !important;
        background: var(--pid-canvas) !important;
        border: 1px solid var(--pid-rule) !important;
        border-radius: 10px !important;
        padding: 0.75rem 1.25rem !important;
        margin: 0.875rem 0 1rem !important;
        box-shadow: 0 20px 40px -24px rgba(13, 13, 13, 0.2), 0 2px 8px -2px rgba(13, 13, 13, 0.08) !important;
        opacity: 1;
        transform: translateY(0);
        pointer-events: auto !important;
        visibility: visible !important;
    }

    /* Child items inside the expanded card */
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container .wp-block-navigation-item {
        padding: 0 !important;
        margin: 0 !important;
    }
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container .wp-block-navigation-item::after {
        display: none !important;
    }
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
        display: flex !important;
        align-items: center !important;
        padding: 0.875rem 0 !important;
        font-family: var(--pid-sans) !important;
        font-size: 1.0625rem !important;
        font-weight: 600 !important;
        color: var(--pid-ink) !important;
        min-height: 48px !important;
        text-decoration: none !important;
        letter-spacing: 0 !important;
        text-transform: none !important;
        width: 100% !important;
    }
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover,
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container .wp-block-navigation-item__content:focus-visible {
        color: var(--pid-magenta) !important;
    }

    /* When the mobile overlay opens, reposition the sole donate button as a
       full-width fixed-bottom CTA inside the overlay. This is the same
       .nav-donate-cta element that shows on desktop/mobile-closed, we just
       re-anchor it visually so mobile users always have a clear donate path
       from inside the menu without duplicating the element in the DOM. */
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open ~ .wp-block-buttons {
        position: fixed !important;
        left: 1.25rem !important;
        right: 1.25rem !important;
        bottom: 1.25rem !important;
        z-index: 100 !important;
        margin: 0 !important;
    }
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open ~ .wp-block-buttons .nav-donate-cta {
        width: 100% !important;
        display: block !important;
    }
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open ~ .wp-block-buttons .nav-donate-cta .wp-block-button__link {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 100% !important;
        min-height: 52px !important;
        padding: 1rem 1.5rem !important;
        font-family: var(--pid-mono) !important;
        font-size: 0.875rem !important;
        font-weight: 600 !important;
        letter-spacing: 0.08em !important;
        text-transform: uppercase !important;
        border-radius: 3px !important;
        background: var(--pid-ink) !important;
        color: var(--pid-canvas) !important;
        box-shadow: 0 20px 40px -18px rgba(13, 13, 13, 0.55) !important;
    }
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open ~ .wp-block-buttons .nav-donate-cta .wp-block-button__link:hover {
        background: var(--pid-magenta) !important;
        color: var(--pid-canvas) !important;
    }

    /* Pad the overlay's inner content so the fixed bottom donate button
       doesn't overlap the last nav item in the list */
    .site-header-wrap .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
        padding-bottom: 6rem !important;
    }

    /* Lock body scroll when the mobile nav overlay is open */
    body:has(.wp-block-navigation__responsive-container.is-menu-open) {
        overflow: hidden;
    }

    .pid-section { padding-block: clamp(2.5rem, 6vw, 4rem); }
    .pid-section-head {
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem;
    }
    .hero-editorial { min-height: min(80vh, 560px); }
    .hero-editorial .wp-block-cover__inner-container,
    .hero-editorial__cover > .wp-block-cover__inner-container {
        padding: 1.25rem;
    }
    .hero-editorial__card {
        max-width: 100%;
        width: 100%;
    }
    .hero-editorial__card h1 { font-size: clamp(1.75rem, 5vw, 2.25rem); }
    .hero-editorial__card .lede { font-size: 1rem; }
    .event-cta-bar {
        flex-direction: column;
        align-items: stretch;
        text-align: center;
        margin-inline: 1rem;
    }
    .event-cta-button { width: 100%; text-align: center; }
    .event-hero-overlay { padding: 2rem 1.25rem; }
    .event-hero-title { font-size: clamp(1.75rem, 6vw, 2.5rem); }
    .stats-inner { gap: 1.5rem; }
    .stat-item { min-width: 0; flex: 1 1 40%; }
    .countdown-inner { gap: 1.25rem; }
    .footer-land-ack { font-size: 0.75rem; padding-inline: 1rem; }
    .pid-timeline { padding-left: 0.25rem; }
}

/* ============================================================
   RESPONSIVE, MOBILE (≤600px)
   ============================================================ */
@media (max-width: 781px) {
    .split-grid { grid-template-columns: 1fr; }
    .split-panel { min-height: 380px; }
}

@media (max-width: 600px) {
    body { font-size: 1rem; line-height: 1.7; }
    p { line-height: 1.75; }
    .pid-section { padding-inline: 1rem; }
    .pid-container { padding-inline: 0; }
    /* Mobile readability floors, ensure no body text drops below 15px */
    .org-card__desc,
    .role-card__body,
    .access-card__body,
    .transit-card__body,
    .community-tile__desc,
    .visit-card__desc,
    .story-card__deck,
    .principle-card__body,
    .hotel-card__body,
    .three-ways-card__desc,
    .sponsor-tier__summary,
    .sponsor-tier__benefits li,
    .resource-index__desc {
        font-size: 0.9375rem;
        line-height: 1.65;
    }
    .wp-block-post-content > p,
    .wp-block-post-content > ul li,
    .wp-block-post-content > ol li {
        line-height: 1.7;
    }
    .events-row { grid-template-columns: 1fr; gap: 1.25rem; }
    .pid-archive-grid { grid-template-columns: 1fr; gap: 1.75rem; }
    .passes-grid { grid-template-columns: 1fr; }
    .mission-icons-grid { grid-template-columns: 1fr; }
    .support-grid { grid-template-columns: 1fr; }
    .story-grid { grid-template-columns: 1fr; gap: 1.75rem; }
    .community-grid { grid-template-columns: 1fr; gap: 1.25rem; }
    .visit-grid { grid-template-columns: 1fr; gap: 0.75rem; }
    .values-grid { grid-template-columns: 1fr; gap: 1rem; }
    .board-grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem 1rem; }
    .download-grid { grid-template-columns: 1fr; }
    .breakdown-legend { grid-template-columns: 1fr; }
    .countdown-inner { gap: 1rem; flex-wrap: wrap; }
    .countdown-unit { min-width: 56px; }
    .countdown-days, .countdown-hours, .countdown-mins, .countdown-secs { font-size: 1.75rem; }
    .countdown-label { width: 100%; text-align: center; }
    .event-tile img { height: 200px; }
    .pid-archive-filters { gap: 0.375rem; }
    .pid-archive-filter-btn {
        font-size: 0.75rem;
        padding: 0.4rem 0.75rem;
        min-height: 44px;
        display: inline-flex;
        align-items: center;
    }
    .site-header-wrap > .wp-block-group.alignwide { padding-inline: 1rem !important; }
    .site-header-wrap .wp-block-navigation a { font-size: 0.875rem; padding: 0.5rem; }
    .site-header-wrap .is-layout-flex { gap: 0.75rem; }
    .nav-donate-cta .wp-block-button__link {
        padding: 0.4rem 0.9rem;
        font-size: 0.75rem;
        min-height: 44px;
        display: inline-flex;
        align-items: center;
    }
    .announcement-bar { font-size: 0.75rem; letter-spacing: 0.06em; padding: 0 0.75rem; height: 34px; }
    .newsletter-form { flex-direction: column; }
    .newsletter-form__submit { width: 100%; min-height: 44px; }
    .hero-editorial { min-height: 60vh; }
    .hero-editorial__card { padding: 1.25rem; }
    .theme-manifesto blockquote { font-size: clamp(1.35rem, 5vw, 1.75rem); }
    .pid-section-head { padding-bottom: 1rem; }
    .pid-section-head h2 { font-size: clamp(1.75rem, 6vw, 2rem); }
    .event-hero-section { min-height: 48vh; }
    .event-cta-bar { padding: 1.25rem; }
    .event-cta-price { font-size: 1.5rem; }
    .split-panel__inner { padding: 1.5rem; }
    .split-panel__inner h3 { font-size: 1.5rem; }
    .download-card { padding: 1.25rem 1.25rem 2.75rem; }
    .value-card { padding: 1.25rem 0; }
    .value-card__title { font-size: 1.375rem; }
    .pid-timeline__item { padding-left: 2.25rem; padding-bottom: 2rem; }
    .pid-timeline__title { font-size: 1.25rem; }
    .wp-block-columns.alignwide { flex-wrap: wrap !important; }
    .wp-block-columns.alignwide > .wp-block-column { flex-basis: 100% !important; }
    .site-footer { padding-inline: 1rem; }
}

/* =======================================================
   2025 SPONSORS graphic (homepage sponsors showcase)
   ======================================================= */
.sponsors-2025 {
    margin: 0 auto;
    max-width: 960px;
    text-align: center;
}
.sponsors-2025__image {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 14px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.18);
}
.sponsors-2025__caption {
    font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.75rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #6B6472;
    margin-top: 1rem;
}

/* =======================================================
   PRESENTED BY SECTION — dedicated band below countdown (home)
   ======================================================= */
.presented-by-section {
    background-color: #FBF7F1;
    padding-block: clamp(2.25rem, 5vw, 3.5rem);
    padding-inline: 1.25rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}
.presented-by-section__inner {
    max-width: 760px;
    margin-inline: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 1.25rem;
}
.presented-by-section__eyebrow {
    font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.75rem;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: #6B6472;
    margin: 0;
}
.presented-by-section__link {
    display: inline-flex;
    align-items: center;
    line-height: 0;
    transition: transform 200ms ease, opacity 200ms ease;
}
.presented-by-section__link:hover,
.presented-by-section__link:focus-visible {
    transform: translateY(-1px);
    opacity: 0.92;
}
.presented-by-section__logo {
    display: block;
    width: auto;
    height: clamp(72px, 11vw, 110px);
    max-width: min(520px, 80vw);
    object-fit: contain;
}
.presented-by-section__tagline {
    font-family: 'Fraunces', Georgia, serif;
    font-style: italic;
    font-size: 1rem;
    color: #4A4550;
    margin: 0;
}
@media (max-width: 600px) {
    .presented-by-section {
        padding-block: 1.75rem;
    }
    .presented-by-section__inner {
        gap: 0.875rem;
    }
    .presented-by-section__eyebrow {
        font-size: 0.6875rem;
        letter-spacing: 0.22em;
    }
    .presented-by-section__logo {
        height: clamp(60px, 18vw, 84px);
    }
    .presented-by-section__tagline {
        font-size: 0.9375rem;
    }
}
