/* Preachers Poster Theme */

:root {
    --black: #050704;
    --green: #9bff33;
    --green-dim: #5f8f1f;
    --bone: #eee1b8;
    --bone-dim: #c8b986;
    --gold: #a88434;
    --max: 1600px;
    --hero-height: min(56.3vw, 941px);
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    background: var(--black);
    color: var(--bone);
    font-family: Georgia, "Times New Roman", serif;
}

a {
    color: inherit;
}

img {
    max-width: 100%;
    height: auto;
}

/* HEADER */

.poster-site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(5, 7, 4, .94);
    border-bottom: 1px solid rgba(155,255,51,.28);
    backdrop-filter: blur(6px);
}

.poster-site-header__inner {
    width: min(var(--max), 96%);
    min-height: 64px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 24px;
}

.poster-site-header__mark {
    display: block;
    width: 58px;
    flex: 0 0 auto;
}

.poster-site-header__mark img {
    display: block;
    width: 100%;
}

.poster-nav {
    flex: 1;
}

.poster-nav__menu {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px 22px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.poster-nav__menu a {
    color: var(--bone);
    text-decoration: none;
    text-transform: uppercase;
    font-weight: 900;
    letter-spacing: .08em;
    font-size: .8rem;
    text-shadow: 2px 2px 0 #000;
}

.poster-nav__menu a:hover {
    color: var(--green);
    text-shadow:
        0 0 10px rgba(155,255,51,.35),
        2px 2px 0 #000;
}
.poster-menu-toggle {
    display: none;
    width: 52px;
    height: 52px;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;

    flex-direction: column;
    justify-content: center;
    gap: 6px;
}

.poster-menu-toggle span {
    display: block;
    width: 24px;
    height: 2px;
    margin: 0 auto;
    background: var(--bone);
}
/* HOME / POSTER CANVAS */

.poster-home {
    background:
        radial-gradient(circle at top, rgba(155,255,51,.08), transparent 34%),
        var(--black);
}

.poster-canvas {
    position: relative;
    overflow: hidden;
    min-height: calc(100vh - 64px);
    background: var(--black);
}

.poster-canvas__texture {
    position: absolute;
    inset: 0;
    background: var(--texture) center center / cover no-repeat;
    opacity: .12;
    mix-blend-mode: overlay;
    pointer-events: none;
}

.poster-canvas__inner {
    position: relative;
    z-index: 2;
    width: 100%;
    min-height: calc(100vh - 64px);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
}

/* HERO ART SECTION */

.poster-brand {
    position: relative;

    width: 100%;
    aspect-ratio: 1672 / 941;
    min-height: 0;

    background:
        linear-gradient(rgba(0,0,0,.03), rgba(0,0,0,.22)),
        var(--desktop-bg) center top / contain no-repeat,
        #050704;

    border-bottom: 2px solid rgba(155,255,51,.28);
    overflow: hidden;
    text-align: center;
}

.poster-brand::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 50% 18%, rgba(238,225,184,.18), transparent 26%),
        linear-gradient(90deg, rgba(0,0,0,.32), transparent 16%, transparent 84%, rgba(0,0,0,.32));
    pointer-events: none;
}

.poster-brand::after {
    content: "";
    position: absolute;
    inset: 10px;
    border: 2px solid rgba(168,132,52,.72);
    box-shadow:
        inset 0 0 0 2px rgba(0,0,0,.7),
        inset 0 0 0 4px rgba(155,255,51,.14);
    pointer-events: none;
}

/* Floating transparent logo slot */
.poster-brand img {
    position: absolute;
    top: -75px;
    left: 52%;
    z-index: 4;
    display: block;
    width: min(980px, 68vw);
    transform: translateX(-50%);
    filter:
        drop-shadow(0 0 18px rgba(155,255,51,.22))
        drop-shadow(0 12px 24px rgba(0,0,0,.85));
}


/* OVERLAY FEATURE PANELS */

.poster-feature,
.poster-ticket {
    position: absolute;
    z-index: 5;
    border: 2px solid rgba(168,132,52,.88);
    background: rgba(5,7,4,.72);
    box-shadow:
        inset 0 0 0 2px rgba(155,255,51,.14),
        0 18px 40px rgba(0,0,0,.48);
    backdrop-filter: blur(2px);
}

.poster-feature {
    top: clamp(86px, 8vw, 132px);
    left: clamp(22px, 5vw, 96px);
    width: min(260px, 18vw);
    min-width: 210px;
    padding: 22px 20px;
    text-align: center;
}

.poster-feature h2 {
    margin: 0 0 10px;
    color: var(--bone);
    text-transform: uppercase;
    line-height: .92;
    font-size: clamp(1.4rem, 1.7vw, 2rem);
    text-shadow: 2px 2px 0 #000;
}

.poster-feature p {
    margin: 0 0 14px;
    color: var(--green);
    text-transform: uppercase;
    font-weight: 900;
    letter-spacing: .04em;
    line-height: 1.15;
}

.poster-ticket {
    top: clamp(82px, 7vw, 126px);
    right: clamp(28px, 5vw, 100px);
    padding: 16px 22px;
    color: var(--bone);
    text-decoration: none;
    text-transform: uppercase;
    font-weight: 900;
    line-height: 1;
    transform: rotate(-6deg);
}

.poster-ticket span {
    color: var(--green);
    font-size: .76rem;
}
/* LIVE FLYER PREVIEW */

.poster-flyer-preview {
    top: clamp(86px, 8vw, 132px);
    left: clamp(22px, 5vw, 96px);

    width: 260px;

    padding: 0;

    background: transparent;
    border: 0;
    box-shadow: none;
    backdrop-filter: none;

    overflow: visible;

    transform: rotate(-4deg);

    transition:
        transform .18s ease,
        filter .18s ease;

    filter:
        drop-shadow(0 18px 34px rgba(0,0,0,.62));
}

.poster-flyer-preview:hover {
    transform:
        rotate(-2deg)
        translateY(-4px);

    filter:
        drop-shadow(0 24px 42px rgba(0,0,0,.72))
        drop-shadow(0 0 16px rgba(155,255,51,.14));
}

.poster-flyer-frame {
    position: relative;
    width: 100%;
    aspect-ratio: 1024 / 1536;
}

.poster-flyer-frame-img {
    position: absolute;
    inset: 0;
    z-index: 2;

    width: 100%;
    height: 100%;

    object-fit: contain;
    pointer-events: none;
}

.poster-flyer-inner {
    position: absolute;
    z-index: 1;

    top: 19%;
    left: 14.5%;

    width: 71%;
    height: 61%;

    overflow: hidden;
    background: #000;
}

.poster-flyer-inner img {
    display: block;
    width: 100% !important;
    height: 100% !important;

    object-fit: contain;
    object-position: center center;

    background: #000;
}
/* GMEDIA RESET */

.poster-flyer-inner .gmedia_gallery,
.poster-flyer-inner .gmedia_container,
.poster-flyer-inner .gmPhantom,
.poster-flyer-inner .gmPhantom_Container {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    height: 100% !important;
}

.poster-flyer-inner img {
    display: block;

    width: 100% !important;
    height: 100% !important;

    object-fit: contain;
    object-position: center top;

    background: #000;
}
/* BUTTONS */

.poster-button,
.poster-module b {
    display: inline-block;
    margin-top: 12px;
    padding: 9px 16px;
    border: 1px solid var(--green);
    color: var(--bone);
    background: rgba(155,255,51,.10);
    text-decoration: none;
    text-transform: uppercase;
    font-weight: 900;
    font-size: .78rem;
    letter-spacing: .04em;
    box-shadow:
        inset 0 0 0 1px rgba(0,0,0,.75),
        0 0 12px rgba(155,255,51,.12);
}

.poster-button:hover,
.poster-module:hover b {
    background: rgba(155,255,51,.22);
    color: var(--green);
}

/* MODULE SECTION BELOW HERO ART */

.poster-module-grid {
    position: relative;
    z-index: 6;

    width: min(var(--max), 96%);
    margin: 0 auto;

    padding: 0;

    display: grid;
    grid-template-columns: repeat(9, minmax(104px, 1fr));

    align-items: center;

    gap: 12px;

    background: #050704;
}

.poster-module-grid::before {
    content: "";

    position: absolute;
    left: 50%;
    top: 50%;

    width: 100vw;
    height: 285px;

    transform: translate(-50%, -50%);
    z-index: -1;

    background:
        linear-gradient(rgba(5,7,4,.12), rgba(5,7,4,.20)),
        url("../img/modules/modules-bg-wide.png") center center / cover no-repeat,
        #050704;
}

.poster-module {
    position: relative;

    aspect-ratio: 3 / 5;

    min-height: 0;
    padding: 0;

    overflow: hidden;

    display: block;

    text-decoration: none;

    border: 0;

    background: transparent;

    box-shadow:
        0 10px 24px rgba(0,0,0,.38);

    transition:
        transform .18s ease,
        box-shadow .18s ease;
}

.poster-module::before {
    display: none;
}

.poster-module:hover {
    transform: translateY(-6px);

    box-shadow:
        0 20px 38px rgba(0,0,0,.62),
        0 0 18px rgba(155,255,51,.10);
}

.poster-module img {
    display: block;

    width: 100%;
    height: 100%;

    object-fit: contain;

    opacity: 1;
}

.poster-module span,
.poster-module small,
.poster-module b {
    display: none !important;
}

/* FOOTER / SOCIALS */

.poster-site-footer {
    background: #050704;
    border-top: 1px solid rgba(155,255,51,.25);
    padding: 26px 0;
    text-align: center;
}

.poster-site-footer__inner {
    width: min(var(--max), 92%);
    margin: 0 auto;
}

.poster-site-footer p {
    margin: 0 0 14px;
    color: var(--green);
    text-transform: uppercase;
    letter-spacing: .1em;
    font-weight: 900;
}

.poster-socials {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 18px;
    margin-bottom: 14px;
}

.poster-socials a {
    color: var(--bone);
    text-transform: uppercase;
    text-decoration: none;
    font-size: .82rem;
    font-weight: 900;
}

.poster-socials a:hover {
    color: var(--green);
}

/* STANDARD CONTENT FALLBACKS */

.content-area {
    width: min(1100px, 92%);
    margin: 70px auto;
}

.content-article,
.archive-card {
    padding: 28px;
    background: rgba(0,0,0,.72);
    border: 1px solid rgba(155,255,51,.25);
}

.archive-grid {
    display: grid;
    gap: 22px;
}

/* RESPONSIVE */

@media (max-width: 1300px) {
    .poster-module-grid {
        grid-template-columns: repeat(5, minmax(120px, 1fr));
    }
}

@media (max-width: 1100px) {
    .poster-site-header__inner {
        flex-direction: column;
        padding: 12px 0;
        gap: 10px;
    }

    .poster-canvas__inner {
        display: block;
        min-height: auto;
    }

    .poster-brand {
        min-height: 72vw;
        background:
            linear-gradient(rgba(0,0,0,.02), rgba(0,0,0,.22)),
            var(--mobile-bg) center 62% / cover no-repeat,
            #050704;
    }

    .poster-brand img {
        width: min(980px, 108vw);
        top: 0;
        left: 52%;
    }

    .poster-feature,
    .poster-ticket {
        display: none;
    }

    .poster-module-grid {
        width: min(760px, 94%);
        grid-template-columns: repeat(3, 1fr);
        gap: 12px;
        padding: 10px 0;
    }

    .poster-module {
        min-height: 0;
        padding: 0;
        aspect-ratio: 3 / 5;
    }

    .poster-module img {
        width: 100%;
        height: 100%;
        max-height: none;
        object-fit: contain;
    }
}
@media (max-width: 900px) and (min-width: 761px) {

    .poster-brand {
        min-height: 200vw;

        background:
            linear-gradient(rgba(0,0,0,.02), rgba(0,0,0,.22)),
            var(--mobile-bg) center 82% / cover no-repeat,
            #050704;
    }

    .poster-brand img {
        width: 130vw;
        top: 60px;
        left: 50%;
    }

    .poster-module-grid {
        width: min(760px, 94%);
        grid-template-columns: repeat(3, 1fr);
        gap: 12px;
    }

}
@media (max-width: 760px) {
    .poster-menu-toggle {
        display: flex;
    }

    .poster-nav {
        position: absolute;
        top: 64px;
        left: 0;
        width: 100%;
        background: rgba(5,7,4,.98);
        border-top: 1px solid rgba(155,255,51,.24);
        display: none;
    }

    .poster-nav.is-open {
        display: block;
    }

    .poster-nav__menu {
        flex-direction: column;
        gap: 0;
        padding: 12px 0;
    }

    .poster-nav__menu li {
        width: 100%;
    }

    .poster-nav__menu a {
        display: block;
        padding: 14px 22px;
        border-bottom: 1px solid rgba(155,255,51,.12);
    }

    .poster-site-header__inner {
        min-height: 56px;
        flex-direction: row;
        justify-content: center;
    }

    .poster-site-header__mark {
        width: 52px;
    }

    .poster-brand {
        min-height: 76vw;
        background:
            linear-gradient(rgba(0,0,0,.02), rgba(0,0,0,.22)),
            var(--mobile-bg) center 68% / cover no-repeat,
            #050704;
    }

    .poster-brand img {
        width: min(108vw, 760px);
        top: 0;
        left: 52%;
    }

    .poster-module-grid {
        width: min(520px, 94%);
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .poster-module {
        min-height: 0;
        padding: 0;
    }
}

@media (max-width: 520px) {

   .poster-brand {
    min-height: 108vw;

    background:
        linear-gradient(rgba(0,0,0,.02), rgba(0,0,0,.22)),
        var(--mobile-bg) center 82% / cover no-repeat,
        #050704;
}

.poster-brand img {
    width: 60vw;
    top: 2px;
    left: 50%;
}


    .poster-module-grid {
        width: min(390px, 94%);
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }

    .poster-module {
        min-height: 0;
        padding: 0;
    }

    .poster-socials {
        gap: 12px;
    }

    .poster-socials a {
        font-size: .74rem;
    }
}