.modal-overlay {
    position: fixed;
    inset: 0;
    display: none;
    place-items: center;
    background: rgba(0,0,0,0.55);
    z-index: 2200;
    padding: 1.2rem;
}
.modal-overlay.is-open { display: grid; }
.modal-window {
    width: min(920px, 100%);
    max-height: 92vh;
    overflow: auto;
    background: var(--admin-panel);
    border: 1px solid var(--admin-line);
    color: var(--admin-text);
    padding: 1.4rem;
    border-radius: 12px;
    box-shadow: 0 24px 44px rgba(0,0,0,0.6);
    position: relative;
}
.modal-close {
    position: absolute;
    top: 12px;
    right: 12px;
    border: 0;
    background: var(--sun);
    color: var(--ink);
    padding: 0.45rem 0.7rem;
    border-radius: 8px;
    cursor: pointer;
    font-size: 1.1rem;
}
.modal-header {
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}
.modal-body {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 1rem;
}
.modal-media img { width: 100%; height: 210px; object-fit: cover; border-radius: 10px; border: 1px solid var(--admin-line); }
.modal-meta { display: grid; gap: 0.6rem; }
.modal-row { display:flex; gap: 0.6rem; align-items:flex-start; }
.modal-row strong { min-width:110px; color: var(--admin-muted); }
.modal-actions { display:flex; gap:0.6rem; }

/* clickable rows for vendor and ticket lists */
.vendor-row, .order-row {
    cursor: pointer;
}
.vendor-row:hover td, .order-row:hover td {
    background: rgba(255,255,255,0.02);
}

/* Give vendor Business column more horizontal space on wider screens without shifting layout */
@media (min-width: 960px) {
    .vendor-table-section .admin-table th:first-child,
    .vendor-table-section .admin-table td[data-label="Business"] {
        max-width: calc(380px + 5ch);
        /* prefer a little extra space but don't force table layout */
        width: auto;
    }
    .vendor-table-section .admin-table td[data-label="Business"] strong {
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
        white-space: normal;
        word-break: break-word;
        max-width: 100%;
        /* slight compression to fit a few more characters without widening layout */
        font-size: 0.98em;
        letter-spacing: -0.035ch;
        line-height: 1.06;
    }
}

/* Keep status and submitted date on one line at desktop widths */
@media (min-width: 760px) {
    .admin-table td[data-label="Status"],
    .admin-table td[data-label="Submitted"] {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .admin-table td[data-label="Status"] .badge {
        white-space: nowrap;
    }
}

@media (max-width: 760px) {
    .modal-body { grid-template-columns: 1fr; }
    .modal-media img { height: 160px; }
}
:root {
    --ink: #130e08;
    --ink-soft: #605344;
    --muted: #8f7f6c;
    --paper: #f7efe1;
    --cream: #ead7ba;
    --white: #fffaf2;
    --sun: #f2bf3a;
    --orange: #e9562b;
    --red: #b64a30;
    --peach: #ddb178;
    --lime: #39b262;
    --teal: #6f9d73;
    --pink: #c57a5f;
    --earth: #9d5a40;
    --navy: #1b130e;
    --shadow-hard: 8px 8px 0 var(--ink);
    --shadow-soft: 0 24px 40px rgba(7, 7, 7, 0.18);
    --admin-bg: #0d0907;
    --admin-panel: #17110d;
    --admin-panel-alt: #221913;
    --admin-text: #fff6e7;
    --admin-muted: #d7c7ae;
    --admin-line: rgba(255, 255, 255, 0.08);
}

/* Strong override: ensure admin pages using public-site theme stay full-width */
body.admin-site.public-site .section-shell,
body.admin-site.public-site .site-shell,
body.admin-site.public-site .admin-layout,
body.admin-site.public-site .admin-main {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

body.admin-site.public-site .section-shell {
    width: 100% !important;
    padding: 0.6rem 0.75rem !important;
}

body.admin-site.public-site .admin-panel {
    width: 100% !important;
    margin: 0 0 1rem 0 !important;
}


* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    min-height: 100vh;
    background: var(--admin-bg);
    color: var(--admin-text);
    font-family: "Outfit", "Segoe UI", sans-serif;
    line-height: 1.6;
}

body.public-site {
    background: var(--paper);
    color: var(--ink);
    overflow-x: hidden;
}

a {
    color: inherit;
    text-decoration: none;
}

img {
    display: block;
    max-width: 100%;
}

button,
input,
select,
textarea {
    font: inherit;
}

main {
    display: block;
}

h1,
h2,
h3,
h4 {
    margin: 0;
    font-family: "Fredoka", "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0;
}

p {
    margin: 0;
}

.skip-link {
    position: absolute;
    left: -9999px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.skip-link:focus {
    position: fixed;
    left: 1rem;
    top: 1rem;
    z-index: 120;
    width: auto;
    height: auto;
    padding: 0.9rem 1rem;
    border-radius: 999px;
    background: var(--sun);
    color: var(--ink);
    box-shadow: var(--shadow-hard);
}

a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
    outline: 3px solid rgba(255, 216, 73, 0.55);
    outline-offset: 3px;
}

.site-shell {
    position: relative;
}

.section-shell {
    width: min(calc(100% - 2rem), 1220px);
    margin: 0 auto;
}

.section-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    font-size: 0.85rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.section-tag::before {
    content: "";
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--sun);
    box-shadow: 3px 3px 0 var(--ink);
}

.section-title {
    font-size: clamp(2.5rem, 5vw, 5.3rem);
    line-height: 0.95;
}

.section-title--light,
.section-copy--light,
.page-hero-copy--light .section-title,
.page-hero-copy--light .section-copy,
.split-copy--light .section-title,
.split-copy--light .section-copy {
    color: var(--white);
}

.section-copy {
    max-width: 740px;
    font-size: 1.08rem;
    color: var(--ink-soft);
}

.section-intro,
.centered-copy,
.gallery-intro {
    display: grid;
    gap: 1rem;
}

.section-intro--light .section-tag,
.page-hero-copy--light .section-tag,
.split-copy--light .section-tag {
    color: var(--white);
}

.section-intro--light .section-title,
.section-intro--light .section-copy {
    color: var(--white);
}

.section-heading {
    display: grid;
    gap: 1rem;
}

.button-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
    align-items: center;
}

.button-row--center {
    justify-content: center;
}

.btn,
.nav-cta,
.watch-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 56px;
    padding: 0.95rem 1.4rem;
    border: 3px solid var(--ink);
    border-radius: 0;
    font-family: "Fredoka", "Outfit", sans-serif;
    font-size: 1rem;
    font-weight: 700;
    text-transform: uppercase;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
    cursor: pointer;
}

.btn:hover,
.nav-cta:hover,
.watch-button:hover,
.nav-link:hover,
.action-card:hover,
.filter-chip:hover,
.gallery-card:hover,
.feature-photo:hover,
.photo-card:hover {
    transform: translate(-2px, -2px);
}

.btn-sun,
.nav-cta,
.watch-button {
    background: var(--sun);
    color: var(--ink);
    box-shadow: var(--shadow-hard);
}

.btn-dark {
    background: var(--ink);
    color: var(--white);
    border-color: var(--white);
    box-shadow: 8px 8px 0 rgba(233, 86, 43, 0.88);
}

.btn-outline-light {
    background: rgba(255, 255, 255, 0.08);
    color: var(--white);
    border-color: var(--white);
    box-shadow: none;
}

.btn.primary {
    background: var(--sun);
    color: var(--ink);
    box-shadow: var(--shadow-hard);
}

.btn.secondary {
    background: rgba(255, 255, 255, 0.08);
    color: inherit;
    box-shadow: none;
}

.btn.ghost {
    background: transparent;
    color: inherit;
    box-shadow: none;
}

.btn.small {
    min-height: 44px;
    padding: 0.7rem 1rem;
    font-size: 0.88rem;
}

.public-site .site-header {
    position: sticky;
    top: 0;
    z-index: 90;
    background: rgba(255, 252, 245, 0.96);
    border-bottom: 4px solid var(--ink);
    backdrop-filter: blur(14px);
}

.navbar {
    width: min(calc(100% - 2rem), 1280px);
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 1.25rem;
    padding: 1.4rem 0;
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: 0.8rem;
}

.brand-seal,
.brand-mark {
    display: grid;
    place-items: center;
    width: 52px;
    height: 52px;
    border: 3px solid var(--ink);
    background: var(--sun);
    color: var(--ink);
    font-family: "Fredoka", "Outfit", sans-serif;
    font-size: 1.4rem;
    font-weight: 700;
    box-shadow: 5px 5px 0 var(--ink);
}

/* Logo image overrides when an actual image is provided */
img.brand-seal.brand-logo,
img.brand-mark.brand-logo {
    display: block;
    width: 52px;
    height: 52px;
    object-fit: contain;
    border: none;
    background: transparent;
    box-shadow: none;
    padding: 0;
}

.brand-logo {
    border-radius: 8px;
}

/* Logo alignment tweaks to match text height and keep nav responsive */
.brand {
    align-items: center;
}

.brand-lockup {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.brand-name span {
    line-height: 1;
}

/* Make logos slightly smaller on very small screens to avoid wrapping */
@media (max-width: 560px) {
    img.brand-seal.brand-logo,
    img.brand-mark.brand-logo {
        width: 44px;
        height: 44px;
    }

    .brand-name span {
        font-size: 1.16rem;
    }
}

/* SVG logos: remove rounded corners and let the artwork show */
img.brand-logo[src$=".svg"] {
    border-radius: 0;
    background: transparent;
}

.brand-lockup,
.brand-text {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}

.brand-name {
    display: flex;
    flex-direction: column;
    line-height: 0.8;
}

.brand-name span {
    font-family: "Baloo 2", "Fredoka", sans-serif;
    font-size: 1.55rem;
    font-weight: 800;
    color: #ff9f8e;
    text-shadow: 0 3px 0 var(--white), 0 6px 0 var(--ink);
}

.brand-label,
.brand-text small {
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--orange);
}

.brand-text strong {
    font-family: "Fredoka", "Outfit", sans-serif;
    font-size: 1.1rem;
}

.nav-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-left: auto;
}

.nav-menu {
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.nav-link {
    padding: 0.7rem 0.9rem;
    font-family: "Fredoka", "Outfit", sans-serif;
    font-size: 0.98rem;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--ink);
    transition: color 0.18s ease;
}

.nav-link.is-active {
    color: var(--orange);
}

.nav-cta--mobile {
    display: none;
}

.nav-toggle {
    display: none;
    width: 52px;
    height: 52px;
    padding: 0;
    border: 3px solid var(--ink);
    background: var(--white);
    box-shadow: 5px 5px 0 var(--ink);
    cursor: pointer;
}

.nav-toggle span {
    display: block;
    width: 22px;
    height: 3px;
    margin: 4px auto;
    background: var(--ink);
}

.hero-showcase {
    position: relative;
    min-height: calc(100vh - 96px);
    background: var(--ink);
    border-bottom: 4px solid var(--ink);
}

.hero-showcase::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: linear-gradient(90deg, rgba(7, 7, 7, 0.74), rgba(7, 7, 7, 0.32)), linear-gradient(180deg, rgba(7, 7, 7, 0.18), rgba(7, 7, 7, 0.58)), var(--hero-image);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.hero-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.8fr);
    gap: 2.5rem;
    align-items: center;
    padding: 4rem 0 3.8rem;
}

.hero-copy {
    display: grid;
    gap: 1.25rem;
    color: var(--white);
}

.date-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.8rem;
    width: fit-content;
    padding: 1rem 1.6rem;
    border: 3px solid var(--white);
    background: var(--orange);
    box-shadow: 8px 8px 0 var(--sun);
    font-family: "Fredoka", "Outfit", sans-serif;
    font-size: 1.35rem;
    font-weight: 700;
    text-transform: uppercase;
}

.date-dot {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--sun);
}

.display-lockup {
    position: relative;
    width: fit-content;
    margin-top: 0.4rem;
}

.display-brand {
    display: inline-block;
    max-width: 8ch;
    font-family: "Baloo 2", "Fredoka", sans-serif;
    font-size: clamp(4.6rem, 11vw, 9.8rem);
    line-height: 0.84;
    font-weight: 800;
    color: #ffab95;
    letter-spacing: 0;
    text-shadow: 0 4px 0 var(--white), 0 10px 0 var(--ink);
    -webkit-text-stroke: 4px var(--ink);
}

.display-mark {
    position: absolute;
    top: 0.5rem;
    right: -1rem;
    padding: 0.3rem 0.8rem;
    border-radius: 999px;
    background: var(--sun);
    color: var(--ink);
    border: 3px solid var(--ink);
    font-family: "Fredoka", "Outfit", sans-serif;
    font-size: 1.2rem;
    font-weight: 700;
    box-shadow: 4px 4px 0 var(--ink);
}

.hero-kicker {
    max-width: 11ch;
    font-size: clamp(2.3rem, 4.3vw, 4.2rem);
    line-height: 0.94;
    text-transform: uppercase;
}

.hero-blurb {
    max-width: 650px;
    font-size: 1.12rem;
    color: rgba(255, 255, 255, 0.88);
}

.hero-meta,
.pill-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
}

.meta-pill,
.pill-row span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0.8rem 1rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.09);
    border: 2px solid rgba(255, 255, 255, 0.2);
    color: var(--white);
    font-weight: 600;
}

.poster-stack,
.action-media,
.highlight-media {
    position: relative;
}

.poster-stack {
    min-height: 560px;
}

.poster-shadow {
    position: absolute;
    inset: auto 0 0 auto;
    width: 82%;
    height: 78%;
    border: 4px solid var(--ink);
}

.poster-shadow--orange {
    right: 3.5rem;
    top: 1rem;
    background: var(--orange);
}

.poster-shadow--sun {
    right: -0.5rem;
    top: 4rem;
    background: var(--sun);
}

.poster-card,
.action-media-card,
.highlight-frame,
.feature-photo,
.photo-card {
    position: relative;
    z-index: 1;
    display: block;
}

.poster-card {
    width: min(100%, 520px);
    margin-left: auto;
    overflow: hidden;
    border: 4px solid var(--white);
    box-shadow: 0 0 0 4px var(--ink);
    background: #000;
    aspect-ratio: 4 / 5;
}

.poster-card img,
.action-media-card img,
.highlight-frame img,
.highlight-frame video,
.feature-photo img,
.gallery-card img,
.photo-card img,
.masonry-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.poster-note {
    position: absolute;
    left: 1rem;
    right: 1rem;
    bottom: 1rem;
    padding: 0.9rem 1rem;
    background: rgba(0, 0, 0, 0.78);
    color: var(--white);
    font-family: "Fredoka", "Outfit", sans-serif;
    font-size: 1.25rem;
    font-weight: 600;
}

.action-shelf {
    background: var(--white);
    border-bottom: 4px solid var(--ink);
}

.action-shelf--flat {
    border-bottom: none;
}

.action-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(320px, 1.05fr);
    gap: 2.4rem;
    align-items: center;
    padding: 0.2rem 0 0;
}

.action-buttons {
    display: grid;
    gap: 1rem;
    padding: 1.2rem 0 0;
}

.action-card {
    display: flex;
    align-items: center;
    min-height: 88px;
    padding: 1.2rem 1.5rem;
    border: 4px solid var(--ink);
    font-family: "Fredoka", "Outfit", sans-serif;
    font-size: 1.6rem;
    font-weight: 700;
    text-transform: uppercase;
}

.action-card--orange {
    background: var(--orange);
    color: var(--white);
    box-shadow: 10px 10px 0 var(--sun);
}

.action-card--light {
    background: var(--white);
    color: var(--ink);
    box-shadow: 10px 10px 0 var(--orange);
}

.action-media {
    min-height: 300px;
}

.action-media-shadow {
    position: absolute;
    inset: 1rem -0.5rem -0.5rem 3rem;
    background: var(--sun);
    border: 4px solid var(--ink);
}

.action-media-card {
    margin-left: auto;
    width: min(100%, 540px);
    border: 4px solid var(--white);
    box-shadow: 0 0 0 4px var(--ink);
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: #000;
}

.category-ribbon {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    margin-top: 1.5rem;
    border-top: 4px solid var(--ink);
}

.category-swatch {
    display: grid;
    place-items: center;
    min-height: 150px;
    padding: 1rem;
    font-family: "Baloo 2", "Fredoka", sans-serif;
    font-size: clamp(2rem, 3vw, 3.15rem);
    font-weight: 800;
    line-height: 0.9;
    text-transform: uppercase;
}

.zone--red {
    background: var(--red);
    color: var(--white);
}

.zone--peach {
    background: var(--peach);
    color: var(--ink);
}

.zone--sun {
    background: var(--sun);
    color: var(--ink);
}

.zone--lime {
    background: var(--lime);
    color: var(--ink);
}

.zone--teal {
    background: var(--teal);
    color: var(--white);
}

.zone--pink {
    background: var(--pink);
    color: var(--white);
}

.zone--earth {
    background: var(--earth);
    color: var(--white);
}

.dark-story-band,
.split-showcase--dark,
.page-hero-section--dark {
    background: var(--navy);
    color: var(--white);
}

.dark-story-band,
.split-showcase--dark {
    background-image: repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.06) 0 2px, transparent 2px 30px);
}

.dark-story-band .section-shell,
.cream-showcase .section-shell,
.split-showcase .section-shell,
.gallery-band .section-shell {
    padding: 4.5rem 0;
}

.stat-grid,
.story-grid,
.schedule-grid,
.package-grid,
.gallery-grid,
.contact-board {
    display: grid;
    gap: 1.5rem;
}

.stat-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 2.3rem;
}

.stat-card,
.story-card,
.schedule-card,
.package-card,
.contact-block,
.map-frame,
.page-hero-card,
.form-card,
.empty-state {
    position: relative;
    border: 4px solid var(--ink);
    background: var(--white);
    color: var(--ink);
    box-shadow: 12px 12px 0 var(--sun);
}

.stat-card {
    --card-accent: var(--sun);
    min-height: 350px;
    padding: 1.9rem;
    background: #000;
    color: var(--white);
    border-color: var(--white);
    box-shadow: 16px 16px 0 var(--card-accent);
}

.stat-card--sun {
    --card-accent: var(--sun);
}

.stat-card--pink {
    --card-accent: var(--pink);
}

.stat-card--lime {
    --card-accent: var(--lime);
}

.stat-card--orange {
    --card-accent: var(--orange);
}

.stat-card--earth {
    --card-accent: var(--earth);
}

.stat-icon {
    display: grid;
    place-items: center;
    width: 70px;
    height: 70px;
    margin-bottom: 1.8rem;
    border: 4px solid var(--white);
    background: var(--card-accent);
    color: var(--ink);
    box-shadow: 8px 8px 0 rgba(255, 255, 255, 0.9);
}

.stat-icon svg {
    width: 32px;
    height: 32px;
}

.stat-value {
    font-size: clamp(3rem, 5vw, 4.7rem);
    line-height: 0.9;
}

.stat-label {
    margin-top: 0.9rem;
    font-family: "Fredoka", "Outfit", sans-serif;
    font-size: 1.2rem;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--card-accent);
}

.stat-copy {
    margin-top: 1rem;
    font-size: 1.02rem;
    color: rgba(255, 255, 255, 0.72);
}

.marquee-strip {
    overflow: hidden;
    border-top: 4px solid var(--ink);
    border-bottom: 4px solid var(--ink);
    background: var(--orange);
    white-space: nowrap;
}

.marquee-track {
    display: inline-flex;
    gap: 2.2rem;
    min-width: 100%;
    padding: 0.7rem 0;
    font-family: "Baloo 2", "Fredoka", sans-serif;
    font-size: clamp(2rem, 4vw, 4rem);
    font-weight: 800;
    color: var(--white);
    text-transform: uppercase;
    text-shadow: 4px 4px 0 var(--ink);
    animation: marquee 24s linear infinite;
}

.marquee-track span::after {
    content: " / ";
}

.energy-band {
    position: relative;
    background: var(--red);
}

.energy-band::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(255, 255, 255, 0.18) 1px, transparent 1px);
    background-size: 22px 22px;
    opacity: 0.32;
}

.highlight-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(320px, 1.08fr);
    gap: 2.2rem;
    align-items: center;
    padding: 4rem 0 4.8rem;
}

.highlight-copy {
    display: grid;
    gap: 1.2rem;
}

.watch-button {
    width: fit-content;
}

.pill-row--light span {
    background: rgba(0, 0, 0, 0.12);
    border-color: rgba(255, 255, 255, 0.24);
}

.highlight-media {
    min-height: 380px;
}

.highlight-corner {
    position: absolute;
    width: 70px;
    height: 70px;
    border: 6px solid currentColor;
}

.highlight-corner--pink {
    top: -18px;
    right: -10px;
    color: var(--pink);
}

.highlight-corner--earth {
    top: -18px;
    right: -10px;
    color: var(--earth);
}

.highlight-corner--lime {
    bottom: -18px;
    left: -10px;
    color: var(--lime);
}

.highlight-frame {
    position: relative;
    z-index: 1;
    width: min(100%, 620px);
    margin-left: auto;
    overflow: hidden;
    border: 4px solid var(--white);
    box-shadow: 0 0 0 4px var(--ink);
    aspect-ratio: 16 / 10;
    background: #000;
}

.highlight-frame--video {
    overflow: hidden;
}

.highlight-video {
    display: block;
    height: 100%;
    object-fit: cover;
}

.details-section,
.split-showcase,
.page-hero-section,
.cream-showcase {
    background: var(--paper);
}

.details-grid,
.page-hero-grid,
.split-showcase-grid,
.contact-layout {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(340px, 1.1fr);
    gap: 2.6rem;
    align-items: start;
    padding: 4.8rem 0;
}

.details-copy,
.page-hero-copy,
.split-copy,
.form-intro {
    display: grid;
    gap: 1rem;
}

.accent-word {
    color: var(--orange);
}

/* Responsive tweaks for small screens: stack highlight area and make video fluid */
@media (max-width: 720px) {
    .highlight-grid {
        grid-template-columns: 1fr;
        gap: 1.2rem;
        padding: 2rem 0 2.6rem;
    }

    .highlight-media {
        min-height: auto;
        display: flex;
        justify-content: center;
        align-items: center;
        padding-top: 0.6rem;
    }

    .highlight-frame {
        width: 100%;
        margin-left: 0;
        border-width: 3px;
        box-shadow: 0 0 0 3px var(--ink);
        aspect-ratio: 16 / 9;
    }

    .highlight-frame--video {
        /* ensure video fills the frame without overflow */
    }

    .highlight-video {
        width: 100%;
        height: auto;
        object-fit: cover;
        max-height: 60vh;
    }

    .highlight-corner {
        display: none;
    }

    .watch-button {
        font-size: 0.95rem;
    }
}

@media (max-width: 420px) {
    .highlight-frame {
        aspect-ratio: 4 / 3;
    }

    .highlight-video {
        max-height: 50vh;
    }
}

.detail-list {
    display: grid;
    gap: 1.3rem;
    margin-top: 1.2rem;
}

.detail-item {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
}

.detail-item h3 {
    font-size: 1.75rem;
    line-height: 0.95;
    text-transform: uppercase;
}

.detail-item p {
    margin-top: 0.45rem;
    font-size: 1.1rem;
    color: var(--ink-soft);
    font-weight: 600;
}

.detail-icon {
    display: grid;
    place-items: center;
    width: 92px;
    height: 92px;
    border: 4px solid var(--ink);
    color: var(--white);
}

.detail-icon svg {
    width: 40px;
    height: 40px;
}

.detail-icon--orange {
    background: var(--orange);
    box-shadow: 8px 8px 0 var(--sun);
}

.detail-icon--red {
    background: var(--red);
    box-shadow: 8px 8px 0 var(--orange);
}

.detail-icon--sun {
    background: var(--sun);
    color: var(--ink);
    box-shadow: 8px 8px 0 var(--peach);
}

.detail-collage {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.4rem 1.8rem;
}

.photo-card {
    --card-accent: var(--sun);
}

.photo-card::before,
.feature-photo::before {
    content: "";
    position: absolute;
    inset: 1rem -1rem -1rem 1rem;
    background: var(--card-accent);
    z-index: 0;
}

.photo-card img,
.feature-photo img {
    position: relative;
    z-index: 1;
    aspect-ratio: 4 / 5;
    border: 4px solid var(--ink);
    box-shadow: var(--shadow-soft);
}

.photo-card--sun {
    --card-accent: var(--sun);
}

.photo-card--earth {
    --card-accent: var(--earth);
}

.photo-card--pink {
    --card-accent: var(--pink);
}

.photo-card--lime {
    --card-accent: var(--lime);
}

.photo-card--teal {
    --card-accent: var(--teal);
}

.gallery-band {
    background: var(--cream);
    border-top: 4px solid var(--ink);
}

.gallery-band--page {
    border-top: none;
}

.gallery-intro {
    max-width: 780px;
    margin: 0 auto 2rem;
    text-align: center;
}

.gallery-summary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    margin: 0.25rem auto 0;
    padding: 0.7rem 1.1rem;
    border: 3px solid var(--ink);
    background: var(--white);
    box-shadow: 8px 8px 0 var(--sun);
    font-family: "Fredoka", "Outfit", sans-serif;
    font-weight: 700;
    text-transform: uppercase;
}

.year-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.4rem;
    margin: 0 auto;
    background: #e7edf5;
    border-radius: 999px;
    box-shadow: 0 14px 24px rgba(7, 7, 7, 0.08);
}

.year-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 138px;
    min-height: 58px;
    padding: 0 1rem;
    border-radius: 999px;
    color: #5b677d;
    font-family: "Fredoka", "Outfit", sans-serif;
    font-size: 1.15rem;
    font-weight: 700;
}

.year-pill.is-active {
    background: #dd2b7a;
    color: var(--white);
}

.gallery-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.gallery-card {
    position: relative;
    overflow: hidden;
    border-radius: 22px;
    background: var(--white);
    box-shadow: 0 18px 34px rgba(7, 7, 7, 0.12);
}

.gallery-card img {
    aspect-ratio: 3 / 4;
}

.gallery-card span {
    position: absolute;
    left: 1rem;
    right: 1rem;
    bottom: 1rem;
    padding: 0.75rem 0.95rem;
    border-radius: 16px;
    background: rgba(7, 7, 7, 0.76);
    color: var(--white);
    font-weight: 700;
}

.centered-action {
    display: flex;
    justify-content: center;
    margin-top: 2rem;
}

.centered-copy--padded {
    padding: 4rem 0 4.8rem;
    text-align: center;
}

.contact-board--offset {
    margin-top: 2rem;
}

.ticket-pass-grid {
    display: grid;
    grid-template-columns: minmax(320px, 420px) minmax(0, 1fr);
    gap: 2rem;
    align-items: start;
    padding: 4.8rem 0;
}

.ticket-pass-panel {
    display: grid;
    gap: 1.25rem;
}

.ticket-qr-card {
    display: grid;
    gap: 1rem;
    padding: 1.6rem;
    border-radius: 20px;
    background: var(--white);
    box-shadow: 12px 12px 0 var(--sun);
}

.ticket-qr-frame {
    display: grid;
    place-items: center;
    min-height: 292px;
    padding: 1rem;
    background: #ffffff;
}

#ticket-qr {
    display: grid;
    place-items: center;
}

#ticket-qr img,
#ticket-qr canvas {
    display: block;
    max-width: 100%;
    height: auto;
}

.ticket-qr-caption {
    margin: 0;
    text-align: center;
    font-weight: 700;
    color: var(--ink-soft);
}

.package-card .highlight-list {
    margin-top: 1rem;
}

.page-hero-section {
    border-bottom: 4px solid var(--ink);
}

.page-hero-section--dark {
    border-bottom-color: var(--white);
}

.page-hero-card {
    padding: 1.8rem;
    display: grid;
    gap: 1rem;
}

.page-hero-card--orange {
    box-shadow: 12px 12px 0 var(--orange);
}

.page-hero-card--pink {
    box-shadow: 12px 12px 0 var(--pink);
}

.page-hero-card--earth {
    box-shadow: 12px 12px 0 var(--earth);
}

.page-hero-card--lime {
    box-shadow: 12px 12px 0 var(--lime);
}

.page-hero-card--sun {
    box-shadow: 12px 12px 0 var(--sun);
}

.page-pill,
.story-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-width: 56px;
    min-height: 46px;
    padding: 0.5rem 0.9rem;
    border: 3px solid var(--ink);
    background: var(--white);
    font-family: "Fredoka", "Outfit", sans-serif;
    font-size: 0.95rem;
    font-weight: 700;
    text-transform: uppercase;
}

.highlight-list {
    display: grid;
    gap: 0.9rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.highlight-list li {
    position: relative;
    padding-left: 1.35rem;
    font-weight: 500;
}

.highlight-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.55rem;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: var(--orange);
}

.highlight-list--dark li {
    color: var(--ink-soft);
}

.story-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 2rem;
}

.story-grid--compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-self: stretch;
}

.story-card,
.schedule-card,
.package-card {
    --card-accent: var(--sun);
    padding: 1.6rem;
    box-shadow: 12px 12px 0 var(--card-accent);
}

.story-card--sun,
.schedule-card--sun,
.package-card--sun {
    --card-accent: var(--sun);
}

.story-card--pink,
.schedule-card--pink,
.package-card--pink {
    --card-accent: var(--pink);
}

.story-card--earth,
.schedule-card--earth,
.package-card--earth {
    --card-accent: var(--earth);
}

.story-card--lime,
.schedule-card--lime,
.package-card--lime {
    --card-accent: var(--lime);
}

.schedule-card--orange,
.package-card--orange {
    --card-accent: var(--orange);
}

.story-card h3,
.schedule-card h3,
.package-card h3,
.contact-block h3,
.map-frame h3 {
    margin-top: 1rem;
    font-size: 1.65rem;
    line-height: 0.95;
    text-transform: uppercase;
}

.story-card p,
.schedule-card p,
.package-card p,
.contact-block p,
.map-frame p {
    margin-top: 0.8rem;
    color: var(--ink-soft);
}

.split-showcase-grid {
    align-items: center;
}

.feature-photo {
    --card-accent: var(--sun);
}

.feature-photo img {
    width: 100%;
}

.feature-photo--sun {
    --card-accent: var(--sun);
}

.feature-photo--earth {
    --card-accent: var(--earth);
}

.feature-photo--pink {
    --card-accent: var(--pink);
}

.schedule-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 2rem;
}

.package-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 2rem;
}

.package-price {
    font-family: "Fredoka", "Outfit", sans-serif;
    font-size: 2.8rem;
    line-height: 0.95;
    color: var(--ink);
}

.contact-layout {
    align-items: start;
}

.contact-board {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.contact-block,
.map-card {
    padding: 1.5rem;
}

.form-card {
    padding: 1.8rem;
    box-shadow: 12px 12px 0 var(--sun);
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.form-field {
    display: grid;
    gap: 0.45rem;
}

.form-field.full {
    grid-column: 1 / -1;
}

.form-field label {
    font-weight: 700;
    color: var(--ink);
}

.form-field input,
.form-field select,
.form-field textarea {
    width: 100%;
    padding: 0.95rem 1rem;
    border: 3px solid var(--ink);
    background: var(--paper);
    color: var(--ink);
    border-radius: 0;
}

/* Password visibility toggle wrapper/button */
.password-wrapper {
    position: relative;
    display: inline-block;
    width: 100%;
}
.password-wrapper input[type="password"],
.password-wrapper input[type="text"] {
    width: 100%;
    padding-right: 44px; /* space for the toggle button */
    box-sizing: border-box;
}
.password-toggle {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    border: 0;
    background: transparent;
    color: inherit;
    cursor: pointer;
    padding: 6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.password-toggle svg {
    width: 20px;
    height: 20px;
    display: block;
}
.password-toggle .icon-hide { display: none; }
.password-toggle.is-shown .icon-hide { display: inline-block; }
.password-toggle.is-shown .icon-show { display: none; }

.form-field textarea {
    resize: vertical;
}

/* Checkbox list: align checkbox with its label text */
.checkbox-list {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    margin-top: 0.6rem;
}

.checkbox-list label {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    font-weight: 700;
}

.checkbox-list input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin: 0;
}

.checkbox-label-text {
    display: block;
}

.alert {
    margin-top: 1rem;
    padding: 1rem 1.1rem;
    border: 3px solid var(--ink);
    font-weight: 700;
    opacity: 1;
    transition: opacity 280ms ease, transform 280ms ease;
}

.alert.success {
    background: #d5ffe0;
    color: var(--ink);
    box-shadow: 8px 8px 0 var(--lime);
}

.alert.error {
    background: #ffe0d8;
    color: var(--ink);
    box-shadow: 8px 8px 0 var(--orange);
}

.alert.warning {
    background: #fff4c6;
    color: var(--ink);
    box-shadow: 8px 8px 0 var(--sun);
}

.map-card {
    display: block;
}

.alert.is-hidden {
    opacity: 0;
    transform: translateY(-6px);
    pointer-events: none;
}

.map-frame {
    padding: 2rem;
    background: var(--ink);
    color: var(--white);
    box-shadow: 12px 12px 0 var(--teal);
}

.map-frame iframe {
    width: 100%;
    height: 360px;
    border: 0;
    display: block;
    border-radius: 8px;
}

@media (max-width: 760px) {
    .map-frame iframe { height: 220px; }
}

.map-frame p {
    color: rgba(255, 255, 255, 0.8);
}

.gallery-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    justify-content: center;
    margin-bottom: 2rem;
}

.filter-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 0 1.2rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.74);
    color: #546077;
    font-family: "Fredoka", "Outfit", sans-serif;
    font-weight: 700;
    transition: transform 0.18s ease, background 0.18s ease, color 0.18s ease;
}

.filter-chip.is-active {
    background: var(--pink);
    color: var(--white);
}

.masonry-grid {
    columns: 3 280px;
    column-gap: 1.3rem;
}

.masonry-item {
    position: relative;
    display: block;
    margin-bottom: 1.3rem;
    break-inside: avoid;
}

.masonry-item img {
    border-radius: 24px;
    box-shadow: 0 18px 34px rgba(7, 7, 7, 0.14);
}

.masonry-caption {
    position: absolute;
    left: 1rem;
    right: 1rem;
    bottom: 1rem;
    padding: 0.8rem 1rem;
    border-radius: 16px;
    background: rgba(7, 7, 7, 0.76);
    color: var(--white);
    font-weight: 700;
}

.empty-state {
    display: grid;
    gap: 1rem;
    max-width: 620px;
    margin: 0 auto;
    padding: 2.2rem;
    text-align: center;
}

.site-footer {
    background: var(--ink);
    color: var(--white);
}

.footer-top-line {
    display: flex;
    height: 18px;
}

.footer-line {
    flex: 1;
}

.footer-line--sun {
    background: var(--sun);
}

.footer-line--orange {
    background: var(--orange);
}

.footer-line--lime {
    background: var(--lime);
}

.footer-line--teal {
    background: var(--teal);
}

.footer-grid {
    width: min(calc(100% - 2rem), 1220px);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1.15fr 0.9fr 0.9fr 0.9fr;
    gap: 2rem;
    padding: 4rem 0 2.5rem;
}

.footer-brand-block {
    display: grid;
    gap: 1.2rem;
}

.brand--footer .brand-seal {
    border-color: var(--white);
    box-shadow: 5px 5px 0 rgba(255, 255, 255, 0.22);
}

.brand--footer .brand-name span {
    text-shadow: 0 3px 0 var(--ink), 0 6px 0 rgba(255, 255, 255, 0.1);
}

.footer-copy {
    max-width: 320px;
    color: rgba(255, 255, 255, 0.78);
}

.footer-dots {
    display: flex;
    gap: 0.75rem;
}

.dot {
    width: 18px;
    height: 18px;
    border-radius: 50%;
}

.dot--red {
    background: var(--red);
}

.dot--sun {
    background: var(--sun);
}

.dot--lime {
    background: var(--lime);
}

.dot--orange {
    background: var(--orange);
}

.dot--pink {
    background: var(--pink);
}

.dot--earth {
    background: var(--earth);
}

.footer-heading {
    margin-bottom: 1rem;
    font-size: 2rem;
    line-height: 0.95;
    text-transform: uppercase;
}

.footer-heading--orange {
    color: var(--orange);
}

.footer-heading--lime {
    color: var(--lime);
}

.footer-heading--pink {
    color: var(--pink);
}

.footer-heading--teal {
    color: var(--teal);
}

.footer-link {
    display: block;
    margin-bottom: 0.7rem;
    color: rgba(255, 255, 255, 0.8);
}

.footer-socials {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
}

.social-link {
    display: grid;
    place-items: center;
    width: 72px;
    height: 72px;
    padding: 0.8rem;
    border: 3px solid var(--white);
    box-shadow: 5px 5px 0 rgba(255, 255, 255, 0.22);
}

.social-link--instagram {
    background: linear-gradient(135deg, #9334e6, #f56040, #feda77);
}

.social-link--tiktok {
    background: #101010;
}

.social-link--snapchat {
    background: var(--sun);
    border-color: var(--ink);
    box-shadow: 5px 5px 0 rgba(255, 216, 73, 0.28);
}

.social-icon {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.footer-bottom {
    width: min(calc(100% - 2rem), 1220px);
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.6rem 0 2.4rem;
    border-top: 1px solid rgba(255, 255, 255, 0.14);
    color: rgba(255, 255, 255, 0.72);
}

/* Footer credit left unstyled by default */

.lightbox {
    position: fixed;
    inset: 0;
    display: none;
    place-items: center;
    padding: 1.5rem;
    background: rgba(7, 7, 7, 0.9);
    z-index: 130;
}

.lightbox.is-open {
    display: grid;
}

.lightbox-inner {
    width: min(1040px, 100%);
    padding: 1rem;
    background: #111111;
    border: 3px solid var(--white);
}

.lightbox-inner img {
    width: 100%;
    max-height: 78vh;
    object-fit: contain;
}

.lightbox-inner p {
    margin-top: 0.9rem;
    color: rgba(255, 255, 255, 0.76);
}

.lightbox-close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    background: var(--sun);
    color: var(--ink);
    border: 3px solid var(--ink);
    padding: 0.8rem 1rem;
    box-shadow: var(--shadow-hard);
}

[data-reveal] {
    opacity: 0;
    transform: translateY(22px);
    transition: opacity 0.55s ease, transform 0.55s ease;
}

[data-reveal].is-visible {
    opacity: 1;
    transform: translateY(0);
}

.admin-shell {
    padding: 1.5rem 0 2rem;
}

/* Accessibility helper: visually hide but keep readable by screen readers */
.sr-only {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* Ensure topbar is positioned so the fixed top-right menu aligns correctly */
.admin-topbar { position: relative; padding-right: 5rem; }

/* When admin pages use the public-site theme, prefer the main site's colors */
body.public-site .admin-sidebar,
body.public-site .admin-topbar,
body.public-site .admin-panel,
body.public-site .admin-auth-card {
    background: var(--af-panel);
    border-color: rgba(255,255,255,0.06);
    color: var(--af-white);
    box-shadow: 0 24px 44px rgba(0,0,0,0.6);
}

body.public-site .admin-brand .brand-mark {
    background: var(--af-lime);
    color: var(--af-black);
}

body.public-site .admin-nav-link {
    color: rgba(255,255,255,0.82);
    background: transparent;
}

body.public-site .admin-nav-link.is-active,
body.public-site .admin-nav-link:hover {
    background: rgba(215,255,63,0.08);
    color: var(--af-white);
}

body.public-site .admin-user-card {
    background: rgba(255,255,255,0.03);
    border-color: rgba(255,255,255,0.04);
}

/* Top-right fixed admin menu (compact access to admin features) */
.admin-topbar-actions {
    position: absolute;
    top: 1rem;
    right: 1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    z-index: 1400;
}

.admin-topbar-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 10px;
    background: rgba(255,255,255,0.03);
    color: var(--af-white);
    border: 1px solid rgba(255,255,255,0.06);
    cursor: pointer;
}

.admin-topbar-menu {
    display: none;
    position: fixed;
    top: 64px;
    right: 1rem;
    width: 260px;
    max-width: calc(100% - 2rem);
    background: var(--af-panel);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 12px;
    box-shadow: 0 12px 40px rgba(0,0,0,0.6);
    padding: 0.6rem;
    z-index: 1450;
}

.admin-topbar-menu.is-open {
    display: block;
}

.admin-topbar-nav {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.admin-topbar-link {
    display: block;
    padding: 0.65rem 0.8rem;
    color: rgba(255,255,255,0.9);
    border-radius: 8px;
}

.admin-topbar-link.is-active,
.admin-topbar-link:hover {
    background: rgba(215,255,63,0.08);
    color: var(--af-white);
}

/* On desktop, hide the left sidebar so admin features are accessed via top menu */
@media (min-width: 981px) {
    /* Desktop: show left sidebar and two-column admin layout */
    .admin-sidebar { display: block; }
    .admin-layout { grid-template-columns: 290px minmax(0, 1fr); }
    /* Ensure top-right hamburger and menu are hidden on desktop */
    .admin-topbar-toggle { display: none !important; }
    .admin-topbar-menu { display: none !important; }
}

.admin-layout {
    width: 100%;
    margin: 0;
    padding: 0 1rem;
    display: grid;
    grid-template-columns: 290px minmax(0, 1fr);
    gap: 1.5rem;
    box-sizing: border-box;
    max-width: 100%;
}

/* Admin content container */
.admin-content {
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

.admin-sidebar,
.admin-topbar,
.admin-panel,
.admin-auth-card {
    border-radius: 24px;
    background: var(--admin-panel);
    border: 1px solid var(--admin-line);
    box-shadow: 0 24px 44px rgba(0, 0, 0, 0.34);
}

.admin-sidebar {
    position: sticky;
    top: 1.5rem;
    height: fit-content;
    padding: 1.4rem;
}

.admin-brand {
    margin-bottom: 1.2rem;
}

.admin-brand .brand-mark {
    background: var(--sun);
}

.admin-nav {
    display: grid;
    gap: 0.6rem;
    margin: 1.5rem 0;
}

.admin-nav-link {
    display: block;
    padding: 0.9rem 1rem;
    border-radius: 16px;
    color: var(--admin-muted);
    background: rgba(255, 255, 255, 0.03);
    transition: background 0.18s ease, color 0.18s ease;
}

.admin-nav-link.is-active,
.admin-nav-link:hover {
    background: rgba(255, 216, 73, 0.12);
    color: var(--admin-text);
}

.admin-user-card {
    display: grid;
    gap: 0.2rem;
    padding: 1rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--admin-line);
}

.admin-user-card span,
.table-meta,
.message-cell,
.admin-gallery-card span {
    color: var(--admin-muted);
}

.admin-main {
    display: grid;
    gap: 1.5rem;
    width: 100%;
    max-width: 100%;
}

/* Ensure sections/articles inside admin-main don't use public theme centering */
.admin-main > section,
.admin-main > article {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box !important;
}

/* Override public theme max-width for admin page sections */
body.admin-site .admin-main > section,
body.admin-site .admin-main > article {
    width: 100% !important;
    max-width: 100% !important;
}

.admin-topbar,
.admin-panel,
.admin-auth-card {
    padding: 1.8rem;
}

.admin-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.2rem;
}

.admin-panel-head a {
    color: var(--sun);
}

.admin-stats-grid,
.admin-content-grid,
.admin-two-column,
.admin-gallery-strip {
    display: grid;
    gap: 1.5rem;
}

.admin-stats-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.admin-content-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-two-column {
    grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
}

.admin-gallery-strip {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.admin-gallery-card {
    padding: 1rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--admin-line);
}

.admin-gallery-card img {
    width: 100%;
    height: 180px;
    object-fit: cover;
    border-radius: 14px;
    margin-bottom: 0.8rem;
}

.admin-table-wrap {
    overflow-x: auto;
}

.admin-table {
    width: 100%;
    min-width: 760px;
    border-collapse: collapse;
}

.admin-table th,
.admin-table td {
    padding: 0.95rem 0.85rem;
    border-top: 1px solid var(--admin-line);
    text-align: left;
    vertical-align: top;
}

.admin-table thead th {
    border-top: none;
    color: var(--sun);
}

.admin-media {
    display: flex;
    align-items: center;
    gap: 0.8rem;
}

.admin-thumb {
    width: 72px;
    height: 72px;
    object-fit: cover;
    border-radius: 14px;
}

.admin-action-row,
.inline-form,
.stack-form {
    display: grid;
    gap: 0.8rem;
}

.inline-form {
    grid-template-columns: minmax(140px, 1fr) auto;
    align-items: center;
}

.badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.4rem 0.75rem;
    border-radius: 999px;
    font-size: 0.84rem;
    font-weight: 700;
}

.badge-success {
    background: rgba(97, 219, 117, 0.14);
    color: #9ef1ad;
}

.badge-warning {
    background: rgba(255, 216, 73, 0.14);
    color: #ffeaa3;
}

.badge-danger {
    background: rgba(255, 106, 60, 0.16);
    color: #ffc2b0;
}

.admin-auth-shell {
    min-height: 100vh;
    display: grid;
    place-items: center;
}

.feature-list {
    display: grid;
    gap: 0.85rem;
    margin: 0;
    padding-left: 1.2rem;
}

.feature-list li {
    color: var(--admin-muted);
}

.admin-site .section-copy,
.admin-site .section-copy--light {
    color: var(--admin-muted);
}

.admin-site .btn.secondary {
    background: rgba(255, 255, 255, 0.05);
    color: var(--admin-text);
    border-color: rgba(255, 255, 255, 0.16);
}

.admin-site .btn.ghost {
    background: transparent;
    color: var(--admin-muted);
    border-color: rgba(255, 255, 255, 0.18);
}

.admin-site .btn.small {
    min-height: 40px;
}

.admin-site .form-field label {
    color: var(--admin-text);
}

.admin-site .form-field input,
.admin-site .form-field select,
.admin-site .form-field textarea {
    background: var(--admin-panel-alt);
    border-color: rgba(255, 255, 255, 0.14);
    color: var(--admin-text);
}

.admin-site .form-field input::placeholder,
.admin-site .form-field textarea::placeholder {
    color: rgba(255, 246, 231, 0.46);
}

.admin-site .form-field input:focus,
.admin-site .form-field select:focus,
.admin-site .form-field textarea:focus {
    border-color: var(--sun);
}

.admin-site .stat-card {
    min-height: auto;
    padding: 1.5rem;
    background: var(--admin-panel-alt);
    color: var(--admin-text);
    border-color: var(--admin-line);
    box-shadow: none;
}

.admin-site .stat-card strong {
    font-family: "Fredoka", "Outfit", sans-serif;
    font-size: 2.5rem;
    line-height: 0.92;
}

.admin-site .stat-card p {
    margin-top: 0.45rem;
    color: var(--admin-muted);
}

.admin-site .admin-action-row {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.admin-site .inline-form select {
    min-width: 0;
}

@keyframes marquee {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

@media (max-width: 1180px) {
    .hero-grid,
    .action-grid,
    .highlight-grid,
    .details-grid,
    .page-hero-grid,
    .split-showcase-grid,
    .contact-layout,
    .admin-layout,
    .admin-two-column,
    .admin-content-grid {
        grid-template-columns: 1fr;
    }

    .poster-card,
    .highlight-frame,
    .action-media-card {
        margin-left: 0;
    }

    .stat-grid,
    .gallery-grid,
    .package-grid,
    .footer-grid,
    .admin-stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .story-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .detail-collage {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .admin-sidebar {
        position: static;
    }
}

@media (max-width: 980px) {
    .navbar {
        position: relative;
        padding: 1rem 0;
    }

    .nav-menu {
        position: absolute;
        top: calc(100% + 0.9rem);
        right: 0;
        left: 0;
        display: none;
        flex-direction: column;
        align-items: stretch;
        padding: 1rem;
        border: 4px solid var(--ink);
        background: var(--white);
        box-shadow: var(--shadow-hard);
    }

    .nav-menu.is-open {
        display: flex;
    }

    .nav-link {
        padding: 0.8rem 0.4rem;
    }

    .nav-cta--desktop {
        display: none;
    }

    .nav-cta--mobile {
        display: inline-flex;
        width: 100%;
        margin-top: 0.8rem;
    }

    .nav-toggle {
        display: inline-block;
    }

    .category-ribbon {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .category-swatch {
        min-height: 120px;
    }
}

/* Admin: ensure sidebar stays visible on small screens and remove hamburger/backdrop usage */
@media (max-width: 980px) {
    /* Remove the left sidebar entirely on small screens */
    .admin-sidebar {
        display: none !important;
    }

    .admin-layout { grid-template-columns: 1fr; }

    /* Ensure topbar menu remains available */
    .admin-nav { display: none; }
    .admin-nav-toggle { display: none !important; }
    .admin-sidebar-backdrop { display: none !important; }
}

/* Improve table responsivity on small screens */
@media (max-width: 760px) {
    .admin-table { min-width: 0; }
    .admin-panel, .admin-topbar { padding-left: 1rem; padding-right: 1rem; }
    .admin-thumb { width: 56px; height: 56px; }
    .admin-panel-head h2 { font-size: 1.05rem; }
}

/* Make admin pages collapse like Events on tablet/phone widths */
@media (max-width: 980px) {
    .admin-two-column,
    .admin-content-grid,
    .admin-gallery-strip,
    .admin-stats-grid {
        grid-template-columns: 1fr !important;
    }

    .admin-panel { padding: 1rem; }
    .admin-topbar { padding: 1rem; }

    /* Tables should not force horizontal scroll; allow cells to wrap */
    .admin-table { min-width: 0 !important; width: 100%; }
    .admin-table td, .admin-table th { white-space: normal; }

    /* Ensure inline forms stack vertically on small screens */
    .inline-form { grid-template-columns: 1fr; gap: 0.6rem; }
    .inline-form select, .inline-form button { width: 100%; }

    /* Make action buttons stack and fit */
    .admin-action-row, .button-row { display: flex; flex-direction: column; gap: 0.6rem; }

    .admin-thumb { width: 56px; height: 56px; }
}

/* Ensure the admin container uses full viewport width on narrow screens to avoid large centered gutters */
@media (max-width: 980px) {
    .admin-layout {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding-left: 0.75rem !important;
        padding-right: 0.75rem !important;
        gap: 1rem;
        grid-template-columns: 1fr !important;
    }

    .admin-main {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        overflow-x: hidden;
    }

    .admin-panel {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 0 1rem 0 !important;
        box-sizing: border-box !important;
    }

    .site-shell {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    /* Tighten admin header spacing so title aligns correctly */
    .admin-topbar {
        padding-left: 0.5rem;
        padding-right: 3.5rem; /* keep space for topbar menu */
    }
}

/* Admin full-bleed overrides for admin pages on small screens */
@media (max-width: 980px) {
    body.admin-site .section-shell,
    body.admin-site .site-shell,
    body.admin-site .admin-layout,
    body.admin-site .admin-main {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    body.admin-site .section-shell {
        box-sizing: border-box;
        padding: 0.6rem 0.75rem;
        margin: 0;
    }

    body.admin-site .admin-panel {
        margin: 0 0 1rem 0;
        width: 100% !important;
        border-radius: 12px;
        padding: 0.9rem;
    }
}

/* Further tighten admin mobile layout: remove extra gutters and make panels full-bleed within padding */
@media (max-width: 760px) {
    .site-shell, .admin-shell, .admin-layout, .admin-main {
        padding-left: 0 !important;
        padding-right: 0 !important;
        margin: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    .admin-panel {
        margin: 0 0 1rem 0;
        border-radius: 12px;
        padding: 0.9rem;
    }

    .admin-panel-head { padding: 0.6rem 0; }
}

@media (max-width: 760px) {
    .section-shell {
        width: min(calc(100% - 1.3rem), 1220px);
    }

    .hero-grid,
    .highlight-grid,
    .details-grid,
    .page-hero-grid,
    .split-showcase-grid,
    .contact-layout {
        gap: 1.8rem;
    }

    .hero-showcase {
        min-height: auto;
    }

    .hero-grid {
        padding: 2.6rem 0 2.8rem;
    }

    .display-brand {
        max-width: 6ch;
        -webkit-text-stroke: 3px var(--ink);
    }

    .display-mark {
        right: auto;
        left: calc(100% - 1rem);
    }

    .date-badge {
        font-size: 1rem;
    }

    .detail-item {
        grid-template-columns: 78px minmax(0, 1fr);
    }

    .detail-icon {
        width: 78px;
        height: 78px;
    }

    .form-grid,
    .story-grid,
    .story-grid--compact,
    .schedule-grid,
    .package-grid,
    .gallery-grid,
    .contact-board,
    .stat-grid,
    .footer-grid,
    .admin-stats-grid,
    .admin-content-grid,
    .admin-two-column {
        grid-template-columns: 1fr;
    }

    .masonry-grid {
        columns: 2 200px;
    }

    .footer-bottom {
        flex-direction: column;
    }

    .admin-nav {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 560px) {
    body.public-site {
        font-size: 15px;
    }

    .brand-seal,
    .brand-mark {
        width: 46px;
        height: 46px;
    }

    .brand-name span {
        font-size: 1.3rem;
    }

    .btn,
    .nav-cta,
    .watch-button {
        width: 100%;
    }

    .button-row,
    .hero-meta,
    .pill-row {
        flex-direction: column;
        align-items: stretch;
    }

    .poster-shadow--orange {
        right: 1.8rem;
    }

    .poster-shadow--sun {
        right: 0;
    }

    .category-ribbon {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .category-swatch {
        min-height: 98px;
        font-size: 1.7rem;
    }

    .detail-collage {
        grid-template-columns: 1fr;
    }

    .masonry-grid {
        columns: 1;
    }

    .year-pill {
        min-width: 112px;
    }

    .admin-nav {
        grid-template-columns: 1fr;
    }

    .inline-form {
        grid-template-columns: 1fr;
    }
}

/* Additional global responsive refinements */
@media (max-width: 720px) {
    .hero-showcase {
        min-height: 50vh;
        padding-bottom: 1.6rem;
    }

    .section-title {
        font-size: clamp(1.6rem, 6vw, 2.6rem);
    }

    .section-copy {
        font-size: 1rem;
    }

    .section-shell {
        width: calc(100% - 1.2rem);
        padding-left: 0.6rem;
        padding-right: 0.6rem;
    }

    /* Ensure large images and videos don't push content off-screen */
    img, video {
        max-width: 100%;
        height: auto;
        display: block;
    }

    /* Lightbox: full-screen friendly on small devices */
    .lightbox {
        position: fixed;
        inset: 0;
        display: none;
        align-items: center;
        justify-content: center;
        background: rgba(0,0,0,0.85);
        z-index: 3000;
        padding: 1rem;
    }

    .lightbox.is-open {
        display: flex;
    }

    .lightbox-inner {
        max-width: 100%;
        max-height: 100%;
        overflow: auto;
        text-align: center;
    }

    #lightbox-image {
        max-width: 100%;
        max-height: 80vh;
        width: auto;
        height: auto;
        margin: 0 auto 0.6rem;
    }

    .lightbox-close {
        position: absolute;
        top: 0.8rem;
        right: 0.8rem;
        z-index: 3010;
        background: var(--sun);
        color: var(--ink);
        border: none;
        padding: 0.6rem 0.8rem;
        border-radius: 8px;
        box-shadow: var(--shadow-hard);
    }

    /* Admin: make tables and panels stack more naturally */
    .admin-table {
        min-width: 0;
        width: 100%;
    }

    .admin-sidebar {
        position: static;
        width: 100%;
    }

    .admin-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 420px) {
    .brand-name span {
        font-size: 1.05rem;
    }

    .nav-link {
        font-size: 0.92rem;
    }

    .section-copy {
        font-size: 0.98rem;
    }

    .btn.primary,
    .nav-cta {
        padding: 0.65rem 0.9rem;
        font-size: 0.95rem;
    }
}

/* AfroFuture-inspired public refresh */
body.public-site {
    --af-black: #101010;
    --af-panel: #151515;
    --af-white: #fffdf4;
    --af-muted: rgba(255, 255, 255, 0.72);
    /* slightly dimmed palette sampled from the logo */
    --af-lime: #a1bf2f;
    --af-magenta: #bf3818; /* dimmed orange-red */
    --af-purple: #912018; /* dimmed deep red */
    --af-orange: #bf5315;
    background: var(--af-black);
    color: var(--af-white);
    font-family: "Outfit", "Segoe UI", sans-serif;
}

/* Sections that use light/cream backgrounds should use dark text when on the public-site theme */
body.public-site .cream-showcase,
body.public-site .page-hero-section,
body.public-site .details-section,
body.public-site .split-showcase,
body.public-site .gallery-band {
    background: var(--af-panel);
    color: var(--af-white);
}

body.public-site .cream-showcase .section-title,
body.public-site .cream-showcase .section-copy,
body.public-site .page-hero-section .section-title,
body.public-site .page-hero-section .section-copy,
body.public-site .details-section .section-title,
body.public-site .details-section .section-copy,
body.public-site .split-showcase .section-title,
body.public-site .split-showcase .section-copy,
body.public-site .gallery-band .section-title,
body.public-site .gallery-band .section-copy,
body.public-site .page-hero-card,
body.public-site .form-card,
body.public-site .form-intro {
    color: var(--af-white);
}

body.public-site .cream-showcase a,
body.public-site .page-hero-section a,
body.public-site .gallery-band a,
body.public-site .split-showcase a {
    color: var(--af-orange);
}

/* Ensure buttons on cream background use readable styles */
body.public-site .cream-showcase .btn,
body.public-site .page-hero-section .btn {
    color: var(--af-white);
    background: transparent;
    border-color: rgba(255,255,255,0.08);
}

body.public-site *,
body.public-site *::before,
body.public-site *::after {
    letter-spacing: 0;
}

/* Ensure form controls are readable on the dark public-site theme (covers pages like media.php) */
body.public-site .form-field input,
body.public-site .form-field select,
body.public-site .form-field textarea {
    border-color: rgba(255, 255, 255, 0.18);
    background: #101010;
    color: var(--af-white);
}

body.public-site .form-field input::placeholder,
body.public-site .form-field textarea::placeholder {
    color: rgba(255, 255, 255, 0.56);
}

/* Quick fix: force public-site form texts to white for readability */
body.public-site .form-card,
body.public-site .form-card *,
body.public-site .form-intro,
body.public-site .form-intro * {
    color: var(--af-white) !important;
}

body.public-site .form-field input,
body.public-site .form-field select,
body.public-site .form-field textarea {
    color: var(--af-white) !important;
}

body.public-site .form-field input::placeholder,
body.public-site .form-field textarea::placeholder {
    color: rgba(255,255,255,0.9) !important;
}

body.public-site h1,
body.public-site h2,
body.public-site h3,
body.public-site .display-brand,
body.public-site .section-title,
body.public-site .af-display,
body.public-site .af-section-heading h1,
body.public-site .af-event-card h3,
body.public-site .af-event-card h2,
body.public-site .af-feature-card h3,
body.public-site .footer-company {
    font-family: "Anton", Impact, "Arial Black", sans-serif;
    font-weight: 400;
    text-transform: uppercase;
    line-height: 0.92;
}

body.public-site .section-shell {
    width: min(calc(100% - 4rem), 1520px);
}

/* Override for admin pages that have both admin-site and public-site classes */
body.admin-site.public-site .section-shell {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0.4rem 0.6rem !important;
}

body.public-site .site-shell {
    overflow: hidden;
}

body.public-site .site-header {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    z-index: 100;
    border: 0;
    background: transparent;
    backdrop-filter: none;
}

body.public-site .navbar {
    width: 100%;
    max-width: none;
    padding: 1.8rem 2.8rem;
}

body.public-site .brand-lockup {
    display: none;
}

body.public-site .brand-wordmark,
body.public-site .footer-wordmark {
    display: inline-flex;
    flex-direction: column;
    color: var(--af-white);
    font-family: "Anton", Impact, sans-serif;
    font-size: 1.55rem;
    line-height: 0.86;
    text-transform: uppercase;
    transform: skew(-8deg) rotate(-5deg);
    text-shadow: 2px 2px 0 rgba(0, 0, 0, 0.65);
}

body.public-site .brand-wordmark span:first-child,
body.public-site .footer-wordmark span:first-child {
    font-size: 0.92em;
}

body.public-site img.brand-seal.brand-logo,
body.public-site img.brand-mark.brand-logo {
    width: 98px;
    height: 84px;
    object-fit: contain;
    border-radius: 14px;
    filter: none;
}

body.public-site .brand-seal {
    border: 0;
    box-shadow: none;
    background: transparent;
    color: var(--af-white);
}

body.public-site .nav-actions {
    margin-left: auto;
}

body.public-site .nav-menu {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: auto;
    z-index: 110;
    display: none;
    width: min(440px, 100%);
    height: 100vh;
    padding: 8rem 2rem 2rem;
    border: 0;
    background: rgba(10, 10, 10, 0.98);
    box-shadow: -24px 0 80px rgba(0, 0, 0, 0.45);
}

body.public-site .nav-menu.is-open {
    display: grid;
    align-content: start;
    gap: 0.35rem;
}

body.public-site .nav-link {
    padding: 0.8rem 0;
    color: var(--af-white);
    font-family: "Anton", Impact, sans-serif;
    font-size: 2.7rem;
    line-height: 0.95;
    text-transform: uppercase;
}

body.public-site .nav-link.is-active,
body.public-site .nav-link:hover {
    color: var(--af-lime);
}

body.public-site .nav-cta--desktop {
    display: none;
}

body.public-site .nav-cta--mobile {
    display: inline-flex;
    width: fit-content;
    margin-top: 1.2rem;
    min-height: 48px;
    border: 0;
    border-radius: 999px;
    background: var(--af-lime);
    color: #080808;
    box-shadow: none;
}

body.public-site .nav-toggle {
    position: relative;
    z-index: 120;
    display: inline-grid;
    place-items: center;
    width: 64px;
    height: 52px;
    border: 0;
    background: transparent;
    box-shadow: none;
}

body.public-site .nav-toggle span {
    width: 36px;
    height: 3px;
    margin: 0;
    background: var(--af-white);
}

body.public-site .nav-toggle span + span {
    margin-top: 8px;
}

body.public-site .btn,
body.public-site .nav-cta,
body.public-site .watch-button {
    border: 0;
    border-radius: 999px;
    box-shadow: none;
    font-family: "Outfit", sans-serif;
    font-weight: 800;
}

body.public-site .btn-sun,
body.public-site .btn.primary,
body.public-site .watch-button,
body.public-site .af-lime-button {
    background: var(--af-lime);
    color: #080808;
}

body.public-site .btn-dark,
body.public-site .btn-outline-light,
body.public-site .btn.secondary,
body.public-site .btn.ghost {
    border: 2px solid var(--af-white);
    background: transparent;
    color: var(--af-white);
}

.af-hero {
    position: relative;
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 8rem 2.8rem 2.5rem;
    background:
        linear-gradient(180deg, rgba(0, 0, 0, 0.18), rgba(0, 0, 0, 0.42)),
        linear-gradient(90deg, rgba(0, 0, 0, 0.12), rgba(0, 0, 0, 0.18)),
        var(--hero-image);
    background-size: cover;
    background-position: center;
}

/* when a video exists, make it act as a full-cover background */
.af-hero {
    overflow: hidden;
}

.af-hero__video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 0;
    pointer-events: none;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    background: transparent;
}

/* ensure overlays and content sit above video */
.af-hero::after,
.af-hero__center,
.af-hero__bottom {
    z-index: 1;
    position: relative;
}

.af-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(0, 0, 0, 0.18), rgba(0, 0, 0, 0.42) 82%),
        radial-gradient(circle at 50% 52%, rgba(0, 0, 0, 0.02) 0 24%, rgba(0, 0, 0, 0.52) 82%);
    pointer-events: none;
}

.af-hero__center {
    position: relative;
    z-index: 1;
    width: min(980px, 100%);
    text-align: center;
}

.af-kicker {
    margin-bottom: 0.9rem;
    font-weight: 800;
    color: var(--af-lime);
    text-shadow: 0 3px 14px rgba(0, 0, 0, 0.72);
    text-transform: uppercase;
}

.af-hero h1 {
    margin: 0;
    color: var(--af-white);
    font-size: 6rem;
    text-shadow: 0 5px 22px rgba(0, 0, 0, 0.72);
}

.af-hero__bottom {
    position: absolute;
    right: 2.8rem;
    bottom: 2.2rem;
    left: 2.8rem;
    z-index: 1;
    display: flex;
    justify-content: space-between;
    gap: 2rem;
    color: var(--af-white);
    font-weight: 800;
    line-height: 1.15;
    text-shadow: 0 4px 18px rgba(0, 0, 0, 0.72);
    text-transform: uppercase;
}

.af-hero__bottom p:last-child {
    text-align: right;
}

.af-events-section {
    padding: 6rem 2rem 9rem;
    background:
        /* center radial uses a dimmed warm tone from the logo */
        radial-gradient(circle at 18% 5%, rgba(191, 56, 24, 0.60), transparent 30rem),
        linear-gradient(135deg, var(--af-magenta) 0%, var(--af-purple) 44%, #07000c 100%);
}

/* Improve contrast in AF-themed dark sections */
.af-events-section,
.af-sponsors-section,
.af-subscribe-section,
.af-feature-grid .af-feature-card,
.af-photo-break {
    color: var(--af-white);
}

.af-events-section a,
.af-events-section .af-event-card h3,
.af-events-section .af-event-card p,
.af-section-heading h2,
.af-section-heading p,
.af-sponsors-section span,
.af-subscribe-copy p,
.af-feature-card h3,
.af-feature-card p {
    color: var(--af-white);
}

/* Ensure links/buttons stand out */
.af-events-section a.footer-link,
.af-events-section a {
    color: var(--af-lime);
}

/* Additional dark-section contrast fixes for other pages */
body.public-site .page-hero-section,
.dark-story-band,
.split-showcase--dark,
.gallery-band,
.cream-showcase.split-showcase--dark,
.split-showcase--dark .split-copy--light {
    color: var(--af-white);
}

body.public-site .page-hero-section .section-title,
body.public-site .page-hero-section .section-copy,
.dark-story-band .section-title,
.dark-story-band .section-copy,
.split-showcase--dark .section-title,
.split-showcase--dark .section-copy,
.gallery-band .section-title,
.gallery-band .section-copy,
.page-hero-card,
.page-hero-card *,
.highlight-list--dark li {
    color: var(--af-white);
}

/* Ensure gallery captions stay readable */
.masonry-caption {
    color: var(--af-white);
}

/* For cream-showcase blocks that sit over dark backgrounds, use stronger contrast */
.cream-showcase .section-title,
.cream-showcase .section-copy {
    color: var(--af-white);
}

.af-events-section--page {
    padding-top: 10rem;
}

.af-section-heading {
    width: min(920px, 100%);
    margin: 0 auto 4rem;
    text-align: center;
}

.af-section-heading span,
.af-subscribe-copy span {
    display: inline-block;
    margin-bottom: 1.2rem;
    color: #d4b8ff;
    font-weight: 800;
    text-transform: uppercase;
}

.af-section-heading h2 {
    margin: 0;
    color: var(--af-white);
    font-size: 5.5rem;
}

.af-section-heading h1 {
    margin: 0;
    color: var(--af-white);
    font-size: 5.8rem;
}

.af-section-heading h2 strong,
.af-subscribe-copy h2 strong {
    display: inline-block;
    color: transparent;
    background: linear-gradient(90deg, #ff5034, #7e42ff);
    -webkit-background-clip: text;
    background-clip: text;
}

.af-section-heading p,
.af-subscribe-copy p {
    margin: 1.4rem auto 0;
    max-width: 760px;
    color: var(--af-white);
    font-size: 1.35rem;
    line-height: 1.35;
}

.af-event-grid {
    width: min(1420px, 100%);
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 4.5rem;
}

.af-event-card {
    display: grid;
    overflow: hidden;
    border-radius: 24px;
    background: #101010;
    color: var(--af-white);
    transition: transform 0.22s ease;
}

.af-event-card:hover {
    transform: translateY(-8px);
}

.af-event-card__image {
    min-height: 360px;
    overflow: hidden;
    background: #0a0a0a;
}

.af-event-card__image img {
    width: 100%;
    height: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    filter: saturate(1.1) contrast(1.02);
}

.af-event-card__body {
    display: grid;
    gap: 1rem;
    padding: 2.2rem;
}

.af-event-card h3 {
    font-size: 3.3rem;
}

.af-event-card h2 {
    font-size: 3.3rem;
}

.af-event-card p {
    font-family: "Anton", Impact, sans-serif;
    font-size: 1.65rem;
    text-transform: uppercase;
}

.af-pill-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
}

.af-pill-row span,
.af-lime-button,
.footer-email-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 44px;
    padding: 0.7rem 1.1rem;
    border-radius: 999px;
    background: var(--af-lime);
    color: #080808;
    font-weight: 900;
    text-transform: uppercase;
}

.af-outline-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 66px;
    padding: 0.85rem 1.5rem;
    border: 3px solid #060606;
    border-radius: 10px;
    background: var(--af-white);
    color: #080808;
    box-shadow: 9px 9px 0 var(--af-white);
    font-weight: 900;
    text-transform: uppercase;
}

.af-explore-section {
    padding: 6rem 2.2rem 8rem;
    background: #181818;
}

.af-feature-grid {
    width: min(1800px, 100%);
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 2rem;
}

.af-feature-card {
    position: relative;
    min-height: 360px;
    overflow: hidden;
    border-radius: 14px;
    background: #0a0a0a;
    color: var(--af-white);
}

.af-feature-card--wide {
    grid-column: span 2;
}

.af-feature-card img {
    width: 100%;
    height: 100%;
    min-height: 360px;
    object-fit: cover;
    transition: transform 0.35s ease;
}

.af-feature-card:hover img {
    transform: scale(1.04);
}

.af-feature-card__shade {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.06), rgba(0, 0, 0, 0.34) 48%, rgba(0, 0, 0, 0.84) 100%);
}

.af-feature-card div {
    position: absolute;
    right: 2rem;
    bottom: 2rem;
    left: 2rem;
    z-index: 1;
}

.af-feature-card h3 {
    font-size: 3.6rem;
    text-shadow: 0 4px 18px rgba(0, 0, 0, 0.78);
}

.af-feature-card p {
    max-width: 720px;
    margin-top: 0.9rem;
    color: rgba(255, 255, 255, 0.86);
    font-size: 1.15rem;
    font-weight: 700;
    text-shadow: 0 3px 14px rgba(0, 0, 0, 0.82);
}

.af-sponsors-section {
    overflow: hidden;
    /* reduced vertical padding to remove excessive top/bottom whitespace */
    padding: 3rem 0 2rem;
    background: var(--af-white);
    color: #060606;
    text-align: center;
}

.af-sponsors-section h2 {
    /* tighten heading spacing */
    margin-bottom: 2rem;
    font-family: "Outfit", sans-serif;
    font-size: 1.6rem;
    font-weight: 900;
    text-transform: uppercase;
}

.af-sponsors-section {
    overflow: hidden; /* hide scrollgap and ensure seamless marquee */
}

.af-sponsor-track {
    display: flex;
    /* reduce horizontal gap between logos to tighten the row */
    gap: 1.5rem;
    align-items: center;
    min-width: 100%;
    /* make the sponsor/media track full-bleed and remove side padding */
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    box-sizing: border-box;
    padding: 0;
    white-space: nowrap;
    animation: marquee 26s linear infinite;
    will-change: transform;
}

.af-sponsor-track span {
    display: inline-flex;
    align-items: center;
    min-height: 80px;
    font-family: Georgia, serif;
    font-size: 2.3rem;
    font-weight: 700;
    color: #16213c;
}

/* Logo support for sponsor/media carousels */
.af-sponsor-track .sponsor-logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    /* increased by 40%: allow larger logos so they read clearly */
    min-width: 280px;
    /* add 1cm extra horizontal spacing around each logo per request */
    padding: 0 calc(0.6rem + 1cm);
}
.af-sponsor-track .sponsor-logo img {
    height: 224px; /* 160 * 1.4 */
    max-height: 224px;
    width: auto;
    object-fit: contain;
    display: block;
}
@media (max-width: 980px) {
    .af-sponsor-track {
        /* slightly faster on narrow screens and reduced gap */
        animation-duration: 18s;
        gap: 1.5rem;
    }
    .af-sponsor-track .sponsor-logo {
        min-width: 252px; /* 180 * 1.4 */
        padding: 0 calc(0.75rem + 1cm);
    }
    .af-sponsor-track .sponsor-logo img { height: 196px; max-height:196px; }
}
@media (max-width: 760px) {
    .af-sponsor-track {
        /* faster marquee on small screens so movement feels natural */
        animation-duration: 14s;
        gap: 1rem;
    }
    .af-sponsor-track .sponsor-logo {
        min-width: 196px; /* 140 * 1.4 */
        padding: 0 calc(0.6rem + 1cm);
    }
    .af-sponsor-track .sponsor-logo img { height: 140px; max-height:140px; }
    .af-sponsor-track span { font-size: 1.6rem; }
}

.af-subscribe-section {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(420px, 1fr);
    min-height: 720px;
    background:
        linear-gradient(135deg, rgba(255, 73, 34, 0.86), rgba(36, 0, 82, 0.55) 48%, rgba(4, 10, 25, 0.96)),
        #101010;
}

.af-subscribe-section--compact {
    min-height: 560px;
}

.af-subscribe-copy {
    display: grid;
    align-content: center;
    padding: 5rem 4.5rem;
    background: #101010;
}

.af-subscribe-copy h2 {
    color: var(--af-white);
    font-size: 5.2rem;
}

.af-subscribe-copy .af-lime-button {
    margin-top: 2rem;
    text-transform: none;
}

.af-cta-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    align-content: center;
    padding: 5rem 4rem;
}

.af-cta-card {
    min-height: 260px;
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    padding: 2rem;
    border-radius: 18px;
    background: #101010;
    color: var(--af-white);
}

.af-cta-card--wide {
    grid-column: span 2;
}

.af-cta-card span {
    font-family: "Anton", Impact, sans-serif;
    font-size: 2.6rem;
    line-height: 0.95;
    text-transform: uppercase;
}

.af-cta-card strong {
    font-size: 3rem;
    line-height: 1;
}

.af-photo-break {
    min-height: 72vh;
    background:
        linear-gradient(180deg, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0.12)),
        var(--photo-break-image);
    background-position: center 42%;
    background-size: cover;
}

body.public-site .site-footer {
    background: #101010;
    color: var(--af-white);
}

body.public-site .footer-grid {
    width: min(calc(100% - 5rem), 1780px);
    grid-template-columns: 1.3fr 0.75fr 0.75fr 0.75fr;
    gap: 4rem;
    padding: 5rem 0 4rem;
}

body.public-site .footer-logo {
    width: 138px;
    max-width: 100%;
    height: auto;
    object-fit: contain;
    border-radius: 18px;
    filter: none;
}

body.public-site .footer-logo-link {
    display: inline-flex;
    width: fit-content;
}

body.public-site .footer-wordmark {
    font-size: 3.1rem;
}

body.public-site .footer-mark {
    display: inline-grid;
    place-items: center;
    width: 84px;
    height: 84px;
    border-radius: 50%;
    background: var(--af-lime);
    color: #080808;
    font-family: "Anton", Impact, sans-serif;
    font-size: 2.2rem;
}

body.public-site .footer-company {
    margin-top: 2.5rem;
    font-family: "Outfit", sans-serif;
    font-size: 2.7rem;
    line-height: 1.02;
    text-transform: none;
}

body.public-site .footer-email-pill {
    margin-top: 2rem;
    text-transform: none;
}

body.public-site .footer-heading {
    margin-bottom: 2rem;
    color: var(--af-white);
    font-family: "Outfit", sans-serif;
    font-size: 1.05rem;
    font-weight: 900;
    text-transform: uppercase;
}

body.public-site .footer-link {
    margin-bottom: 1.25rem;
    color: rgba(255, 255, 255, 0.84);
    font-size: 1.35rem;
}

body.public-site .footer-link:hover {
    color: var(--af-lime);
}

body.public-site .footer-link--muted {
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.58);
}

body.public-site .filter-chip {
    background: rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.88);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

body.public-site .filter-chip.is-active {
    background: var(--af-lime);
    color: #080808;
    box-shadow: none;
}

body.public-site .gallery-summary {
    color: #080808;
}

body.public-site .footer-socials {
    margin-top: 2rem;
    gap: 1.1rem;
}

body.public-site .social-link {
    display: inline-grid;
    place-items: center;
    width: 44px;
    height: 44px;
    padding: 0;
    border: 0;
    border-radius: 12px;
    background: transparent;
    box-shadow: none;
}

body.public-site .social-icon {
    width: 100%;
    height: 100%;
    object-fit: contain;
    filter: none;
}

body.public-site .social-link--tiktok {
    overflow: hidden;
    background: #ffffff;
}

body.public-site .footer-bottom {
    width: min(calc(100% - 5rem), 1780px);
    padding: 1.5rem 0 2.5rem;
    color: rgba(255, 255, 255, 0.58);
}

body.public-site .page-hero-section,
body.public-site .cream-showcase,
body.public-site .details-section,
body.public-site .gallery-band {
    background: #101010;
    color: var(--af-white);
}

body.public-site .page-hero-section {
    border: 0;
    padding-top: 5rem;
}

body.public-site .page-hero-grid,
body.public-site .details-grid,
body.public-site .split-showcase-grid,
body.public-site .contact-layout {
    padding-top: 6.5rem;
}

body.public-site .section-title,
body.public-site .page-hero-copy .section-title,
body.public-site .split-copy .section-title {
    color: var(--af-white);
}

body.public-site .section-copy,
body.public-site .page-hero-copy .section-copy,
body.public-site .split-copy .section-copy {
    color: rgba(255, 255, 255, 0.78);
}

body.public-site .section-tag {
    color: #d4b8ff;
}

body.public-site .section-tag::before {
    display: none;
}

body.public-site .page-hero-card,
body.public-site .story-card,
body.public-site .schedule-card,
body.public-site .package-card,
body.public-site .contact-block,
body.public-site .form-card,
body.public-site .map-frame,
body.public-site .empty-state {
    border: 0;
    border-radius: 20px;
    background: #171717;
    color: var(--af-white);
    box-shadow: none;
}

body.public-site .highlight-list--dark li,
body.public-site .story-card p,
body.public-site .schedule-card p,
body.public-site .package-card p,
body.public-site .contact-block p,
body.public-site .map-frame p {
    color: rgba(255, 255, 255, 0.72);
}

body.public-site .page-pill,
body.public-site .story-number {
    border: 0;
    border-radius: 999px;
    background: var(--af-lime);
    color: #080808;
}

body.public-page-vendors .form-intro,
body.public-page-vendors .form-card,
body.public-page-vendors .form-field label,
body.public-page-contact .form-intro,
body.public-page-contact .form-card,
body.public-page-contact .form-field label,
body.public-page-tickets .form-intro,
body.public-page-tickets .form-card,
body.public-page-tickets .form-field label,
body.public-page-ticket-pass .ticket-pass-panel {
    color: var(--af-white);
}

body.public-page-vendors .form-field input,
body.public-page-vendors .form-field select,
body.public-page-vendors .form-field textarea,
body.public-page-contact .form-field input,
body.public-page-contact .form-field select,
body.public-page-contact .form-field textarea,
body.public-page-tickets .form-field input,
body.public-page-tickets .form-field select,
body.public-page-tickets .form-field textarea {
    border-color: rgba(255, 255, 255, 0.18);
    background: #101010;
    color: var(--af-white);
}

body.public-page-vendors .form-field input::placeholder,
body.public-page-vendors .form-field textarea::placeholder,
body.public-page-contact .form-field input::placeholder,
body.public-page-contact .form-field textarea::placeholder,
body.public-page-tickets .form-field input::placeholder,
body.public-page-tickets .form-field textarea::placeholder {
    color: rgba(255, 255, 255, 0.56);
}

body.public-page-tickets .form-field input:disabled {
    color: rgba(255, 255, 255, 0.72);
    opacity: 1;
}

body.public-page-ticket-pass .ticket-qr-card {
    background: #171717;
    color: var(--af-white);
    box-shadow: none;
}

body.public-page-ticket-pass .ticket-qr-frame {
    border-radius: 18px;
}

body.public-page-ticket-pass .ticket-qr-caption {
    color: rgba(255, 255, 255, 0.76);
}

.approved-vendors-section {
    padding: 2rem 0 5.5rem;
    background: #101010;
    color: var(--af-white);
}

/* Bakatue polaroid carousel */
.polaroid-section { padding: 3rem 0; }
/* Heading before the polaroid carousel */
.polaroid-header { text-align: center; margin-bottom: 1rem; }
.polaroid-title {
    font-family: 'Anton', sans-serif;
    font-size: clamp(28px, 6vw, 56px);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin: 0;
    color: var(--af-white); /* ensure contrast on dark public-site background */
}
@media (max-width: 760px) {
    .polaroid-title { font-size: clamp(20px, 8vw, 36px); }
}

.history-panel {
    background: rgba(255,255,255,0.02);
    border: 2px solid rgba(255,255,255,0.85);
    border-radius: 18px;
    padding: 2.5rem 2rem;
    margin-bottom: 1.6rem;
    box-shadow: 0 18px 48px rgba(0,0,0,0.55);
}
.history-inner { max-width: 960px; margin: 0 auto; text-align: center; }
.history-tag { display: block; font-size: 0.75rem; letter-spacing: 0.18em; color: rgba(255,255,255,0.6); margin-bottom: 0.6rem; text-transform: uppercase; }
.history-title { font-family: 'Anton', sans-serif; font-size: clamp(36px, 7vw, 72px); line-height: 0.92; margin: 0 0 1rem 0; color: var(--af-white); }
.history-copy { max-width: 880px; margin: 0 auto; color: rgba(255,255,255,0.86); font-size: 1.05rem; }

/* small inner spacing for the hero area inside the panel */
.history-hero { padding-bottom: 1.2rem; }

@media (max-width: 760px) {
    .history-panel { padding: 1.6rem 1rem; }
    .history-copy { font-size: 0.95rem; }
    .history-title { font-size: clamp(22px, 9vw, 38px); }
}
.polaroid-carousel {
    overflow: visible;
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    box-sizing: border-box;
    padding: 0; /* remove side padding so polaroids reach edges */
}
.polaroid-viewport { overflow: visible; max-width: 100%; }
.polaroid-track {
    display: flex;
    align-items: center;
    /* overlap items visually by using negative margins */
    gap: 0;
    animation: polaroid-scroll 51s linear infinite; /* reduced speed by 40% (slower) */
}
.polaroid-item {
    flex: 0 0 380px; /* larger items */
    background: #fff;
    border-radius: 12px;
    padding: 0.6rem;
    box-shadow: 0 28px 60px rgba(0,0,0,0.6);
    border: 18px solid #fff; /* thicker polaroid border */
    margin-left: -100px; /* overlap */
    transition: transform 220ms ease;
}
.polaroid-item:first-child { margin-left: 0; }
.polaroid-item img { width: 100%; height: 320px; object-fit: cover; display: block; border-radius: 8px; }
.polaroid-track .polaroid-item:nth-child(4n+1) { transform: rotate(-8deg); }
.polaroid-track .polaroid-item:nth-child(4n+2) { transform: rotate(4deg); }
.polaroid-track .polaroid-item:nth-child(4n+3) { transform: rotate(-3deg); }
.polaroid-track .polaroid-item:nth-child(4n+4) { transform: rotate(6deg); }

@keyframes polaroid-scroll {
    from { transform: translateX(0); }
    /* translate by the pixel width of one sequence (set via --polaroid-scroll)
       fallback to 50% for older browsers */
    to { transform: translateX(calc(-1 * var(--polaroid-scroll, 50%))); }
}

@media (max-width: 760px) {
    .polaroid-item { flex: 0 0 280px; margin-left: -60px; }
    .polaroid-item img { height: 240px; }
    .polaroid-track { animation-duration: 36.8s; } /* reduced speed by 40% */
}

/* Elmina slideshow */
.elmina-slideshow {
    /* full-bleed like the polaroid carousel */
    overflow: visible;
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    box-sizing: border-box;
    padding: 0;
    background: #0f0f0f;
}
.elmina-slides {
    position: relative;
    width: 100%;
    height: 66vh; /* ~2/3 of viewport height */
    max-height: 80vh;
    overflow: hidden;
}
.elmina-slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 900ms ease, transform 900ms ease;
    transform-origin: center;
}
.elmina-slide.is-active { opacity: 1; z-index: 2; }
.elmina-slide img { width: 100%; height: 100%; object-fit: cover; object-position: center center; display: block; }

/* Slight adjustment for very wide screens: shift crop slightly upward to keep subject visible */
@media (min-width: 1400px) {
    .elmina-slide img { object-position: center 45%; }
}
.elmina-caption { position: absolute; left: 50%; transform: translateX(-50%); bottom: 18px; z-index: 3; background: rgba(0,0,0,0.45); padding: 0.5rem 1rem; border-radius: 999px; color: var(--af-white); }
.elmina-caption-title { margin: 0; font-family: 'Anton', sans-serif; font-size: 20px; letter-spacing: 0.08em; }
.elmina-slide .slide-placeholder { display:flex; align-items:center; justify-content:center; height:100%; color:rgba(255,255,255,0.7); }

@media (max-width: 760px) {
    .elmina-slides { height: 45vh; }
}

/* On desktop show the whole image with letterboxing so nothing is clipped */
@media (min-width: 981px) {
    .elmina-slide img {
        object-fit: contain;
        object-position: center center;
        background-color: #0f0f0f;
    }
}

/* Elmina grid */
.elmina-grid { margin-top: 1.2rem; display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.2rem; }
@media (max-width: 980px) { .elmina-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px) { .elmina-grid { grid-template-columns: 1fr; } }


/* Offset main anchor so Skip to content doesn't push carousel flush to top */
#main { scroll-margin-top: 80px; }

/* Bakatue section (mirrors 'why' layout) */
.bakatue-section { padding: 4rem 0; }
.bakatue-section .why-panel { background: transparent; }
.bakatue-section .why-inner { display: grid; gap: 1.4rem; }
.bakatue-section .why-header { text-align: center; margin-bottom: 2rem; }
.bakatue-section .why-title { font-size: clamp(2rem, 4vw, 3.8rem); margin: 0.4rem 0; }
.bakatue-section .why-copy { max-width: 760px; margin: 0 auto 1.6rem; }
.bakatue-section .why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; margin-top: 1.6rem; }
.bakatue-section .why-feature h3 { margin-bottom: 0.6rem; }

@media (max-width: 960px) {
    .bakatue-section .why-grid { grid-template-columns: 1fr; }
}

.approved-vendors-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1.5rem;
    align-items: end;
    margin-bottom: 2rem;
}

.approved-vendors-head h2 {
    max-width: 860px;
    color: var(--af-white);
    font-size: 4.4rem;
}

.approved-vendor-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.35rem;
}

.approved-vendor-card,
.approved-vendors-empty {
    overflow: hidden;
    border-radius: 22px;
    background: #171717;
    color: var(--af-white);
}

.approved-vendor-card__media {
    display: grid;
    place-items: center;
    min-height: 280px;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: linear-gradient(135deg, var(--af-purple), var(--af-orange));
}

.approved-vendor-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.approved-vendor-card__media span {
    color: var(--af-lime);
    font-family: "Anton", Impact, sans-serif;
    font-size: 6rem;
    line-height: 1;
}

.approved-vendor-card__body {
    display: grid;
    gap: 0.75rem;
    padding: 1.35rem;
}

.approved-vendor-card__body > span,
.approved-vendor-card__body small {
    width: fit-content;
    color: var(--af-lime);
    font-size: 0.82rem;
    font-weight: 900;
    text-transform: uppercase;
}

.approved-vendor-card__body h3 {
    color: var(--af-white);
    font-size: 2.45rem;
}

.approved-vendor-card__body p,
.approved-vendors-empty p {
    color: rgba(255, 255, 255, 0.72);
}

.approved-vendors-empty {
    display: grid;
    gap: 0.7rem;
    padding: 2rem;
}

.approved-vendors-empty h3 {
    color: var(--af-white);
    font-size: 2.6rem;
}

.event-detail-hero {
    position: relative;
    min-height: 760px;
    padding: 10rem 0 5rem;
    overflow: hidden;
    background: #080808;
    color: var(--af-white);
}

.event-detail-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0.52) 55%, rgba(0, 0, 0, 0.34)),
        linear-gradient(180deg, rgba(0, 0, 0, 0.18), #101010 100%),
        var(--event-image);
    background-position: center;
    background-size: cover;
    transform: scale(1.02);
}

.event-detail-hero__grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 460px);
    gap: 3rem;
    align-items: end;
    min-height: 600px;
}

.event-detail-hero__copy,
.event-checkout-card,
.event-detail-content,
.event-detail-panel {
    display: grid;
    gap: 1.2rem;
}

.event-detail-hero__copy {
    max-width: 920px;
}

.event-back-link {
    width: fit-content;
    color: rgba(255, 255, 255, 0.78);
    font-weight: 800;
    text-transform: uppercase;
}

.event-detail-eyebrow,
.event-meta-strip,
.event-ticket-summary,
.ticket-order-summary {
    display: grid;
    gap: 0.8rem;
}

.event-detail-eyebrow {
    display: flex;
    flex-wrap: wrap;
}

.event-detail-eyebrow span,
.event-price-chip {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 42px;
    padding: 0.7rem 1rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
    color: var(--af-white);
    font-weight: 900;
    text-transform: uppercase;
}

.event-price-chip {
    background: rgba(255, 255, 255, 0.18);
}

.event-price-chip--muted {
    color: rgba(255, 255, 255, 0.76);
}

.event-detail-hero h1 {
    max-width: 11ch;
    font-size: 6rem;
    color: var(--af-white);
}

.event-detail-hero__copy > p {
    max-width: 760px;
    color: rgba(255, 255, 255, 0.82);
    font-size: 1.25rem;
    line-height: 1.45;
}

.event-meta-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    max-width: 980px;
    padding: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 22px;
    background: rgba(16, 16, 16, 0.72);
    backdrop-filter: blur(12px);
}

.event-meta-strip span,
.event-ticket-summary span,
.ticket-order-summary span {
    display: grid;
    gap: 0.25rem;
    min-width: 0;
    padding: 0.95rem;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.08);
}

.event-meta-strip strong,
.event-ticket-summary small,
.ticket-order-summary small,
.event-facts dt {
    color: #d4b8ff;
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.event-checkout-card,
.event-detail-panel {
    padding: 1.45rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 22px;
    background: rgba(18, 18, 18, 0.94);
    color: var(--af-white);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.28);
}

.event-checkout-card__head h2,
.event-detail-panel h3 {
    margin-top: 0.6rem;
    font-size: 2.45rem;
    color: var(--af-white);
}

.event-ticket-summary,
.ticket-order-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.event-ticket-summary strong,
.ticket-order-summary strong {
    color: var(--af-white);
    font-size: 1.05rem;
    line-height: 1.2;
}

.event-quick-form,
.ticket-compact-form {
    display: grid;
    gap: 1rem;
}

.event-quick-form .form-grid,
.ticket-compact-form .form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.event-checkout-card .form-field label,
.ticket-compact-form .form-field label {
    color: var(--af-white);
}

.event-checkout-card .form-field input,
.ticket-compact-form .form-field input {
    min-height: 52px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 12px;
    background: #101010;
    color: var(--af-white);
}

.event-pay-button,
.ticket-pay-button {
    width: 100%;
    min-height: 56px;
    border: 0;
    border-radius: 999px;
    background: var(--af-lime);
    color: #080808;
    box-shadow: none;
}

body.public-site .ticket-checkout-section .ticket-pay-button,
body.public-site .event-checkout-card .event-pay-button {
    border: 0;
    background: var(--af-lime);
    color: #080808;
    box-shadow: none;
}

.event-ticket-note {
    color: rgba(255, 255, 255, 0.74);
}

.event-detail-section,
.ticket-checkout-section {
    background: #101010;
    color: var(--af-white);
}

.event-detail-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 390px);
    gap: 3rem;
    align-items: start;
    padding: 5rem 0 6rem;
}

.event-detail-content h2 {
    color: var(--af-white);
    font-size: 4rem;
}

.event-rich-text {
    max-width: 880px;
    color: rgba(255, 255, 255, 0.78);
    font-size: 1.12rem;
    line-height: 1.75;
}

.event-rich-text p + p,
.event-rich-text ul,
.event-rich-text ol {
    margin-top: 1rem;
}

.event-rich-text a {
    color: var(--af-lime);
    font-weight: 800;
}

.event-detail-panel {
    position: sticky;
    top: 1.5rem;
    background: #171717;
}

.event-facts {
    display: grid;
    gap: 0;
    margin: 0;
}

.event-facts div {
    display: grid;
    gap: 0.25rem;
    padding: 1rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.event-facts div:first-child {
    padding-top: 0;
}

.event-facts dd {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
}

.event-detail-panel .af-lime-button,
.event-detail-panel .af-outline-button {
    width: 100%;
    margin-top: 0.4rem;
}

.ticket-checkout-section {
    padding-top: 5.5rem;
}

.ticket-checkout-section .contact-layout {
    padding-top: 4.5rem;
}

.ticket-form-actions {
    margin-top: 0;
}

@media (max-width: 1180px) {
    .approved-vendor-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .approved-vendors-head {
        grid-template-columns: 1fr;
    }

    .event-detail-hero {
        min-height: auto;
    }

    .event-detail-hero__grid,
    .event-detail-layout {
        grid-template-columns: 1fr;
    }

    .event-detail-hero__grid {
        min-height: 0;
    }

    .event-checkout-card {
        max-width: 620px;
    }

    .event-detail-panel {
        position: static;
    }
}

@media (max-width: 760px) {
    .approved-vendors-section {
        padding: 1rem 0 3.5rem;
    }

    .approved-vendors-head h2 {
        font-size: 3rem;
    }

    .approved-vendor-grid {
        grid-template-columns: 1fr;
    }

    .approved-vendor-card__media {
        min-height: 220px;
    }

    .event-detail-hero {
        padding: 8rem 0 3.5rem;
    }

    .event-detail-hero__grid,
    .event-detail-layout {
        gap: 2rem;
    }

    .event-detail-hero h1 {
        max-width: none;
        font-size: 3.35rem;
    }

    .event-detail-hero__copy > p,
    .event-rich-text {
        font-size: 1rem;
    }

    .event-meta-strip,
    .event-ticket-summary,
    .ticket-order-summary,
    .event-quick-form .form-grid,
    .ticket-compact-form .form-grid {
        grid-template-columns: 1fr;
    }

    .event-checkout-card,
    .event-detail-panel {
        padding: 1rem;
        border-radius: 18px;
    }

    .event-detail-layout {
        padding: 3.5rem 0 4rem;
    }

    .event-detail-content h2 {
        font-size: 2.8rem;
    }

    .event-checkout-card__head h2,
    .event-detail-panel h3 {
        font-size: 2rem;
    }

    .ticket-checkout-section .contact-layout {
        padding-top: 3rem;
    }
}

body.public-site .category-ribbon {
    border: 0;
}

body.public-site .category-swatch {
    font-family: "Anton", Impact, sans-serif;
}

@media (max-width: 1180px) {
    .af-hero h1,
    .af-section-heading h1,
    .af-section-heading h2,
    .af-subscribe-copy h2 {
        font-size: 4.2rem;
    }

    .af-event-grid,
    .af-subscribe-section {
        grid-template-columns: 1fr;
    }

    .af-feature-grid,
    body.public-site .footer-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    body.public-site .section-shell {
        width: min(calc(100% - 1.5rem), 100%);
    }

    body.public-site .navbar {
        padding: 1.1rem 1rem;
    }

    body.public-site img.brand-seal.brand-logo,
    body.public-site img.brand-mark.brand-logo {
        width: 74px;
        height: 62px;
    }

    .af-hero {
        min-height: 760px;
        padding: 7rem 1rem 2rem;
    }

    .af-hero h1,
    .af-section-heading h1,
    .af-section-heading h2,
    .af-subscribe-copy h2 {
        font-size: 3.2rem;
    }

    .af-hero__bottom {
        right: 1rem;
        bottom: 1.2rem;
        left: 1rem;
        flex-direction: column;
    }

    .af-hero__bottom p:last-child {
        text-align: left;
    }

    .af-events-section,
    .af-explore-section {
        padding-right: 1rem;
        padding-left: 1rem;
    }

    .af-event-grid,
    .af-feature-grid,
    .af-cta-grid,
    body.public-site .footer-grid {
        grid-template-columns: 1fr;
    }

    .af-feature-card--wide,
    .af-cta-card--wide {
        grid-column: auto;
    }

    .af-event-card h3,
    .af-event-card h2,
    .af-feature-card h3 {
        font-size: 2.5rem;
    }

    .af-subscribe-copy,
    .af-cta-grid {
        padding: 3.5rem 1rem;
    }

    body.public-site .footer-grid,
    body.public-site .footer-bottom {
        width: min(calc(100% - 2rem), 100%);
    }

    body.public-site .footer-logo {
        width: clamp(72px, 22vw, 84px);
    }

    .ticket-pass-grid {
        grid-template-columns: 1fr;
        padding: 3rem 0;
    }
}

/* Admin responsive consolidation */
body.admin-site.public-site {
    min-width: 0;
    overflow-x: hidden;
}

body.admin-site.public-site .site-shell {
    width: 100% !important;
    max-width: none !important;
    min-height: 100vh;
    overflow: visible !important;
}

body.admin-site.public-site .site-shell.admin-shell {
    padding: clamp(0.75rem, 2vw, 1.5rem) !important;
}

body.admin-site.public-site .site-shell:not(.admin-shell) {
    display: grid;
    place-items: center;
    padding: clamp(0.75rem, 4vw, 2rem) !important;
}

body.admin-site.public-site .admin-layout {
    width: min(100%, 1680px) !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 0 !important;
    grid-template-columns: minmax(240px, 290px) minmax(0, 1fr);
    gap: clamp(1rem, 2vw, 1.5rem);
}

body.admin-site.public-site .admin-panel {
    margin: 0 !important;
}

body.admin-site .admin-main,
body.admin-site .admin-content,
body.admin-site .admin-panel,
body.admin-site .admin-topbar,
body.admin-site .admin-table,
body.admin-site .admin-table td,
body.admin-site .admin-table th {
    min-width: 0;
}

body.admin-site .admin-main {
    align-content: start;
}

body.admin-site .admin-topbar {
    padding-right: 1.8rem !important;
}

body.admin-site .admin-topbar h1,
body.admin-site .admin-panel h2,
body.admin-site .admin-panel h3,
body.admin-site .gallery-table-head h2,
body.admin-site .vendor-table-section h2,
body.admin-site .msg-table-section h2 {
    overflow-wrap: anywhere;
}

body.admin-site .admin-topbar h1 {
    font-size: clamp(2rem, 5vw, 4.4rem);
}

body.admin-site .admin-panel h2,
body.admin-site .gallery-table-head h2,
body.admin-site .vendor-table-section h2,
body.admin-site .msg-table-section h2 {
    font-size: clamp(1.45rem, 3vw, 2.35rem);
}

body.admin-site .admin-panel-head,
body.admin-site .gallery-table-head {
    flex-wrap: wrap;
}

body.admin-site .admin-panel-body {
    display: grid;
    gap: 1rem;
}

body.admin-site .scanner-shell {
    padding: 1rem;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

body.admin-site .scanner-target {
    min-height: 320px;
}

body.admin-site .scanner-note {
    margin-top: 1rem;
    color: var(--admin-muted);
}

body.admin-site .gallery-card,
body.admin-site .gallery-table-section,
body.admin-site .vendor-table-section,
body.admin-site .msg-table-section,
body.admin-site .msg-stat-card {
    background: var(--admin-panel);
    border: 1px solid var(--admin-line);
    color: var(--admin-text);
}

body.admin-site .admin-split-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
    gap: 1.2rem;
    align-items: start;
}

body.admin-site .admin-table-wrap {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

body.admin-site .admin-table {
    table-layout: auto;
}

body.admin-site .admin-table td,
body.admin-site .message-cell {
    overflow-wrap: anywhere;
}

body.admin-site td.admin-table-actions {
    white-space: nowrap;
}

body.admin-site td.admin-table-actions > .btn,
body.admin-site td.admin-table-actions > form {
    margin: 0 0.5rem 0.5rem 0;
    vertical-align: top;
}

body.admin-site td.admin-table-actions form {
    display: inline-flex;
    margin-bottom: 0;
}

body.admin-site td.admin-table-actions .btn {
    min-height: 40px;
}

body.admin-site .admin-table-form {
    display: grid;
    gap: 0.5rem;
}

body.admin-site .admin-form-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.5rem;
    align-items: end;
}

body.admin-site .admin-table-form select,
body.admin-site .admin-form-row select {
    min-width: 0;
}

body.admin-site.public-site .section-shell.admin-auth-shell {
    width: min(100%, 640px) !important;
    max-width: 640px !important;
    min-height: auto;
    margin: 0 auto !important;
    padding: 0 !important;
    place-items: stretch;
}

body.admin-site .admin-auth-card,
body.admin-site .admin-auth-card .form-card {
    width: 100%;
    max-width: 100%;
}

@media (min-width: 981px) {
    body.admin-site .admin-sidebar {
        display: block !important;
    }

    body.admin-site .admin-topbar-toggle,
    body.admin-site .admin-topbar-menu {
        display: none !important;
    }
}

@media (max-width: 1180px) {
    body.admin-site.public-site .admin-layout,
    body.admin-site .admin-two-column,
    body.admin-site .admin-content-grid,
    body.admin-site .admin-split-panel {
        grid-template-columns: 1fr !important;
    }

    body.admin-site .admin-sidebar {
        position: static;
    }
}

@media (max-width: 980px) {
    body.admin-site.public-site .site-shell.admin-shell {
        padding: 0.75rem !important;
    }

    body.admin-site.public-site .admin-layout {
        grid-template-columns: 1fr !important;
        gap: 1rem;
    }

    body.admin-site .admin-sidebar {
        display: none !important;
    }

    body.admin-site .admin-topbar {
        padding: 1rem 4.35rem 1rem 1rem !important;
        border-radius: 18px;
    }

    body.admin-site .admin-topbar-actions {
        top: 0.9rem;
        right: 0.9rem;
    }

    body.admin-site .admin-topbar-toggle {
        display: inline-flex !important;
    }

    body.admin-site .admin-topbar-menu {
        top: 4.85rem;
        right: 0.75rem;
        left: 0.75rem;
        width: auto;
        max-width: none;
        max-height: calc(100vh - 6rem);
        overflow-y: auto;
    }

    body.admin-site .admin-topbar-menu.is-open {
        display: block !important;
    }

    body.admin-site .admin-panel,
    body.admin-site .admin-auth-card,
    body.admin-site .gallery-card,
    body.admin-site .gallery-table-section,
    body.admin-site .vendor-table-section,
    body.admin-site .msg-table-section,
    body.admin-site .msg-stat-card {
        padding: 1rem !important;
        border-radius: 18px !important;
    }

    body.admin-site .admin-stats-grid,
    body.admin-site .admin-content-grid,
    body.admin-site .admin-two-column,
    body.admin-site .admin-gallery-strip,
    body.admin-site .gallery-grid,
    body.admin-site .stats-grid,
    body.admin-site .msg-stats-grid {
        grid-template-columns: 1fr !important;
    }

    body.admin-site .admin-panel-head,
    body.admin-site .gallery-table-head {
        align-items: flex-start;
        flex-direction: column;
    }

    body.admin-site .gallery-table-head .btn {
        width: 100%;
    }
}

@media (max-width: 760px) {
    body.admin-site.public-site .site-shell.admin-shell,
    body.admin-site.public-site .site-shell:not(.admin-shell) {
        padding: 0.6rem !important;
    }

    body.admin-site .admin-main {
        gap: 1rem;
    }

    body.admin-site .admin-topbar h1 {
        font-size: clamp(1.8rem, 10vw, 3rem);
    }

    body.admin-site .admin-topbar .section-copy {
        font-size: 0.96rem;
    }

    body.admin-site .form-grid {
        grid-template-columns: 1fr !important;
    }

    body.admin-site .button-row,
    body.admin-site .admin-action-row {
        align-items: stretch;
    }

    body.admin-site .button-row .btn,
    body.admin-site .admin-action-row .btn,
    body.admin-site .admin-panel-body .btn {
        width: 100%;
    }

    body.admin-site .admin-table-wrap {
        overflow: visible !important;
    }

    body.admin-site .admin-table {
        display: block;
        width: 100% !important;
        min-width: 0 !important;
        border-collapse: separate;
        border-spacing: 0;
    }

    body.admin-site .admin-table thead {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0 0 0 0);
        white-space: nowrap;
        border: 0;
    }

    body.admin-site .admin-table tbody {
        display: grid;
        gap: 0.85rem;
    }

    body.admin-site .admin-table tr {
        display: block;
        padding: 0.9rem;
        border: 1px solid var(--admin-line);
        border-radius: 16px;
        background: rgba(255, 255, 255, 0.035);
    }

    body.admin-site .admin-table td {
        display: grid;
        grid-template-columns: minmax(7.25rem, 36%) minmax(0, 1fr);
        gap: 0.7rem;
        align-items: start;
        padding: 0.7rem 0;
        border-top: 1px solid var(--admin-line);
    }

    body.admin-site .admin-table td:first-child {
        padding-top: 0;
        border-top: 0;
    }

    body.admin-site .admin-table td::before {
        content: attr(data-label);
        color: var(--sun);
        font-size: 0.78rem;
        font-weight: 800;
        letter-spacing: 0.04em;
        text-transform: uppercase;
    }

    body.admin-site .admin-table td:not([data-label]) {
        display: block;
    }

    body.admin-site .admin-table td:not([data-label])::before,
    body.admin-site .admin-table td[colspan]::before {
        content: none;
    }

    body.admin-site .admin-table td[colspan] {
        text-align: center !important;
    }

    body.admin-site .admin-table td[data-label="Actions"] {
        display: block;
    }

    body.admin-site .admin-table td[data-label="Actions"]::before {
        display: block;
        margin-bottom: 0.5rem;
    }

    body.admin-site .admin-media {
        align-items: flex-start;
        flex-direction: column;
        gap: 0.5rem;
    }

    body.admin-site td.admin-table-actions {
        white-space: normal;
    }

    body.admin-site td.admin-table-actions > .btn,
    body.admin-site td.admin-table-actions > form {
        display: flex;
        width: 100%;
        margin: 0 0 0.5rem;
    }

    body.admin-site td.admin-table-actions .btn,
    body.admin-site td.admin-table-actions form .btn {
        width: 100%;
    }
}

@media (max-width: 560px) {
    body.admin-site .admin-panel,
    body.admin-site .admin-auth-card,
    body.admin-site .gallery-card,
    body.admin-site .gallery-table-section,
    body.admin-site .vendor-table-section,
    body.admin-site .msg-table-section,
    body.admin-site .msg-stat-card {
        padding: 0.85rem !important;
        border-radius: 14px !important;
    }

    body.admin-site .admin-topbar {
        padding: 0.9rem 3.95rem 0.9rem 0.9rem !important;
        border-radius: 14px;
    }

    body.admin-site .admin-topbar-toggle {
        width: 40px;
        height: 40px;
    }

    body.admin-site .admin-topbar-actions {
        top: 0.75rem;
        right: 0.75rem;
    }

    body.admin-site .admin-form-row {
        grid-template-columns: 1fr;
    }

    body.admin-site .admin-table td {
        grid-template-columns: 1fr;
        gap: 0.35rem;
    }

    body.admin-site td.admin-table-actions > .btn,
    body.admin-site td.admin-table-actions > form {
        width: 100%;
    }
}
