.pvtv-info-panel h3 {
    margin-top: 0;
    margin-bottom: 1rem;
}

.pvtv-extras-note {
    margin-top: 0.6rem;
    margin-bottom: 0;
    font-size: 0.95em;
    opacity: 0.92;
}

.pvtv-upcoming-dates {
    margin-top: 1rem;
    margin-bottom: 0;
}

.pvtv-project-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.25rem;
}

.pvtv-project-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    background: #111;
    border: 1px solid #333;
    border-radius: 1.25rem;
    overflow: hidden;
}

.pvtv-project-thumb {
    aspect-ratio: 16 / 10;
    overflow: hidden;
}

.pvtv-project-thumb a,
.pvtv-project-thumb img {
    display: block;
    width: 100%;
    height: 100%;
}

.pvtv-project-thumb img {
    object-fit: cover;
}

.pvtv-project-content {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    padding: 1.1rem;
    flex: 1;
}

.pvtv-project-title {
    margin: 0;
    line-height: 0.98;
    font-size: 1.65rem;
}

.pvtv-project-title a,
.pvtv-project-link {
    text-decoration: none;
}

.pvtv-project-text {
    margin: 0;
    line-height: 1.55;
}

.pvtv-project-link-wrap {
    margin: auto 0 0;
    padding-top: 0.35rem;
}

.pvtv-project-meta {
    margin-top: -0.2rem;
    margin-bottom: 0.8rem;
    font-size: 0.95rem;
    opacity: 0.8;
}

.pvtv-film-details {
    margin: 1.5rem 0;
}

.pvtv-film-details-section {
    margin-bottom: 1.2rem;
}

.pvtv-film-details-tagline p {
    margin: 0;
    font-size: 1.55rem;
    font-weight: 700;
    line-height: 1.15;
}

.pvtv-film-details-context p {
    margin: 0;
    font-size: 0.98rem;
    opacity: 0.88;
}

.pvtv-film-details-logline p {
    margin: 0;
    font-size: 1.05rem;
    line-height: 1.55;
}

.pvtv-film-details-synopsis p {
    margin-top: 0;
    margin-bottom: 1rem;
    line-height: 1.65;
}

.pvtv-film-details-synopsis p:last-child {
    margin-bottom: 0;
}

/* Centre the icon row within the column */
.pvtv-film-details-icons {
    display: flex;
    justify-content: center;
}

.pvtv-film-icon-links {
    display: flex;
    gap: 0.65rem;
    align-items: center;
    justify-content: center;
}

.pvtv-film-icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: 1px solid #333;
    border-radius: 7px;
    overflow: hidden;
    background: #111;
    text-decoration: none;
}

.pvtv-film-icon-button img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.pvtv-film-media img,
.pvtv-film-media iframe {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
}

.pvtv-film-media iframe {
    aspect-ratio: 16 / 9;
    height: auto;
}

.pvtv-film-details-synopsis {
    margin-top: 2.25rem;
    margin-bottom: 2.25rem;
}

.pvtv-film-details-synopsis p {
    margin: 0 0 1.2rem 0;
    line-height: 1.65;
}

.pvtv-film-details-synopsis p:last-child {
    margin-bottom: 0;
}

.pvtv-film-facts-list {
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 0.25rem 0.9rem;
    margin: 0;
}

.pvtv-film-facts-list dt {
    font-weight: 700;
    margin: 0;
}

.pvtv-film-facts-list dd {
    margin: 0;
}

.pvtv-film-details-credits h3,
.pvtv-film-details-links h3 {
    margin-bottom: 0.6rem;
}

.pvtv-film-credits-text p {
    margin-top: 0;
}

.pvtv-film-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin: 0;
}

.pvtv-film-links a {
    text-decoration: none;
}

/* Back button */
.pvtv-film-details-back {
    margin-top: 2.5rem;
    margin-bottom: 1rem;
    text-align: center;
}

@media (max-width: 640px) {
    .pvtv-film-details {
        max-width: 100%;
    }

    .pvtv-film-facts-list {
        grid-template-columns: 1fr;
        gap: 0.15rem 0;
    }

    .pvtv-film-facts-list dt {
        margin-top: 0.45rem;
    }
}

@media (max-width: 900px) {
    .pvtv-project-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .pvtv-project-grid {
        grid-template-columns: 1fr;
    }
}

/* Fringe Flicks */

.pvtv-ff-programme-wrap {
    margin: 2rem 0;
}

.pvtv-ff-programme-title {
    margin: 0 0 1rem;
}

.pvtv-ff-programme-grid {
    display: grid;
    gap: 1.25rem;
}

.pvtv-ff-programme-grid.columns-1 {
    grid-template-columns: 1fr;
}

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

.pvtv-ff-programme-grid.columns-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

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

.pvtv-ff-season-films .pvtv-ff-film-card {
    margin-top: 0;
}

.pvtv-ff-film-card {
    align-self: start;
    background: #1f1f1f;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0.4rem;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.pvtv-ff-film-card-image img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

.pvtv-ff-film-card-image {
    margin: 0;
    line-height: 0;
}

.pvtv-ff-film-card-image a {
    display: block;
    margin: 0;
}

.pvtv-ff-film-card-image a:hover img,
.pvtv-ff-film-card-image a:focus img {
    opacity: 0.92;
}

.pvtv-ff-film-card-body {
    padding: 1rem;
}

.pvtv-ff-film-card-title {
    margin: 0 0 0.5rem;
    line-height: 1.15;
}

.pvtv-ff-film-card-title a {
    text-decoration: none;
}

.pvtv-ff-film-card-title a:hover {
    text-decoration: underline;
}

.pvtv-ff-film-card-credits {
    margin: 0 0 0.6rem;
    font-size: 0.95rem;
    opacity: 0.9;
}

.pvtv-ff-film-card-logline {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.45;
}

.pvtv-ff-programme-empty {
    padding: 1rem 1.2rem;
    background: #1f1f1f;
    border-radius: 0.4rem;
}

@media (max-width: 1024px) {
    .pvtv-ff-programme-grid.columns-4,
    .pvtv-ff-programme-grid.columns-3 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .pvtv-ff-programme-grid.columns-4,
    .pvtv-ff-programme-grid.columns-3,
    .pvtv-ff-programme-grid.columns-2 {
        grid-template-columns: 1fr;
    }
}

/* Events */

.pvtv-event-hero {
    margin: 0 0 2.5rem;
    background: #151515;
    border: 1px solid rgba(255, 255, 255, 0.08);
    overflow: hidden;
}

.pvtv-event-hero-media img {
    display: block;
    width: 100%;
    height: auto;
    max-height: 70vh;
    object-fit: cover;
}

.pvtv-event-hero-content {
    padding: 1.25rem;
}

.pvtv-event-hero-title {
    margin: 0 0 0.75rem;
    line-height: 1;
}

.pvtv-event-hero-summary {
    margin: 0 0 1rem;
    font-size: 1.1rem;
    line-height: 1.45;
    max-width: 48rem;
}

/* Hero details */
.pvtv-event-hero-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 2rem;
    row-gap: 1.2rem;
    margin: 0 0 1.2rem;
}

.pvtv-event-hero-meta-item {
    display: block;
}

/* Page section spacing */
.pvtv-event-type-section,
.pvtv-event-support-section {
    margin-top: 2.5rem;
}

.pvtv-ff-section-block {
    margin: 0 0 1.75rem;
}

/* Headings */
.pvtv-ff-section-title {
    margin: 0 0 0.9rem;
    font-size: 1.55rem;
    line-height: 1.05;
}

.pvtv-event-section-title {
    margin: 0 0 0.65rem;
    font-size: 1.1rem;
    line-height: 1.1;
}

.pvtv-event-subsection-title {
    margin: 0 0 0.5rem;
    font-size: 0.98rem;
    line-height: 1.15;
}

/* Text blocks */
.pvtv-ff-section-intro {
    margin: 0 0 1rem;
    max-width: 48rem;
    line-height: 1.5;
}

.pvtv-ff-what-to-expect-text,
.pvtv-event-details-richtext,
.pvtv-event-support-block {
    max-width: 42rem;
}

.pvtv-ff-what-to-expect-text,
.pvtv-event-details-richtext {
    line-height: 1.55;
}

.pvtv-event-details-richtext p,
.pvtv-ff-what-to-expect-text p,
.pvtv-event-support-block p {
    margin: 0 0 0.75rem;
}

.pvtv-event-details-richtext p:last-child,
.pvtv-ff-what-to-expect-text p:last-child,
.pvtv-event-support-block p:last-child {
    margin-bottom: 0;
}

/* Practical details */
.pvtv-event-details-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 2rem;
    row-gap: 1.2rem;
    margin: 0 0 1rem;
}

.pvtv-event-details-item {
    display: block;
}

.pvtv-event-details-label,
.pvtv-event-details-value {
    margin: 0;
}

.pvtv-event-details-extra {
    margin: 0 0 1rem;
    max-width: 42rem;
}

/* Support blocks */
.pvtv-event-support-block {
    margin: 0 0 1.25rem;
}

/* 3. Event button sizing and layout
   Base appearance now comes from the shared .pvtv-button class.
   These rules only handle event-specific sizing/shape behaviour. */
.pvtv-event-hero-button,
.pvtv-ff-ticket-button,
.pvtv-event-button,
.pvtv-event-hero-actions a,
.pvtv-ff-ticket-cta-block a,
.pvtv-event-details-ticket a,
.pvtv-event-support-action a {
    box-sizing: border-box !important;
    width: 12rem !important;
    height: 3.1rem !important;
    padding: 0 1.2rem !important;
    line-height: 1 !important;
    text-align: center !important;
    vertical-align: middle !important;
    white-space: nowrap !important;
}

.pvtv-event-hero-actions,
.pvtv-ff-ticket-cta-block,
.pvtv-event-details-ticket,
.pvtv-event-support-action {
    margin-top: 0.9rem;
}

/* Mobile */
@media (max-width: 640px) {
    .pvtv-event-hero-meta,
    .pvtv-event-details-grid {
        grid-template-columns: 1fr;
    }

    .pvtv-event-hero-button,
    .pvtv-ff-ticket-button,
    .pvtv-event-button,
    .pvtv-event-hero-actions a,
    .pvtv-ff-ticket-cta-block a,
    .pvtv-event-details-ticket a,
    .pvtv-event-support-action a {
        width: 100%;
        max-width: 20rem;
    }
}

/* =========================
   EVENT PAGE FINAL TIDY
   add at very end of file
   ========================= */

/* 1. Make hero + practical details stay as tidy two-column pairs */
.pvtv-event-hero-meta,
.pvtv-event-details-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    column-gap: 2.25rem !important;
    row-gap: 1.35rem !important;
}

/* Force each detail item to behave like a tight label/value stack */
.pvtv-event-hero-meta-item,
.pvtv-event-details-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
    align-self: start !important;
    gap: 0.12rem !important;
    min-height: 0 !important;
}



/* 2. Headings: bigger overall, but lower utility headings smaller than Programme */
.pvtv-ff-section-title {
    font-size: 2rem !important;
    line-height: 1.02 !important;
    margin: 0 0 0.9rem 0 !important;
}

/* What to expect should still feel like a proper section */
.pvtv-event-type-section .pvtv-event-section-title {
    font-size: 1.55rem !important;
    line-height: 1.05 !important;
    margin: 0 0 0.8rem 0 !important;
}

/* Practical details / Supported by / Patreon smaller than the above */
.pvtv-event-section-title,
.pvtv-event-support-section .pvtv-event-section-title {
    font-size: 1.25rem !important;
    line-height: 1.08 !important;
    margin: 0 0 0.65rem 0 !important;
}

/* Practical details panel */
.pvtv-event-practical-details {
    font-size: 1.25rem;
    line-height: 1.08;
    margin-top: 2.5rem;
}

/* 4. Remove the extra lower Book tickets button for now */
.pvtv-event-practical-details .pvtv-event-details-ticket {
    display: none !important;
}

/* 5. Give the Patreon button more breathing room */
.pvtv-event-support-action {
    margin-top: 1.35rem !important;
}

/* 6. Tighten lower-section bulk a bit */
.pvtv-event-support-block {
    margin-bottom: 1.5rem !important;
}

.pvtv-event-details-extra,
.pvtv-event-support-block,
.pvtv-ff-what-to-expect-text,
.pvtv-event-details-richtext {
    max-width: 44rem !important;
}

/* Mobile only */
@media (max-width: 640px) {
    .pvtv-event-hero-meta,
    .pvtv-event-details-grid {
        grid-template-columns: 1fr !important;
    }

    .pvtv-event-hero-button,
    .pvtv-ff-ticket-button,
    .pvtv-event-button,
    .pvtv-event-hero-actions a,
    .pvtv-ff-ticket-cta-block a,
    .pvtv-event-details-ticket a,
    .pvtv-event-support-action a {
        width: 100% !important;
        max-width: 20rem !important;
    }
}

/* =========================
   SHARED SITE COMPONENT BRIDGE
   Temporary compatibility layer.

   These rules allow shortcode markup to start using
   shared site-wide component classes such as:
   .pvtv-panel
   .pvtv-meta-list
   .pvtv-button

   Keep this bridge while older plugin-specific
   selectors still exist elsewhere in this file.
   Remove duplicated legacy base styling gradually.
   ========================= */

/* Shared panel class now used by shortcode wrappers */
.pvtv-panel.pvtv-info-panel {
    margin: 1.5rem 0;
}

/* Shared metadata list now used alongside legacy info list */
.pvtv-meta-list.pvtv-info-list {
    margin: 0;
}

/* Project CTA now opts into the shared site-wide button style.
   Keep link-specific spacing wrapper separate for now. */
.pvtv-project-link.pvtv-button {
    min-width: 0;
}

/* Practical details now also use the shared panel class */
.pvtv-panel.pvtv-event-practical-details {
    margin-top: 2.5rem;
}

/* Event buttons now opt into the shared site-wide button class.
   Base appearance comes from .pvtv-button; event CSS handles sizing only. */
.pvtv-event-hero-button.pvtv-button,
.pvtv-event-button.pvtv-button,
.pvtv-ff-ticket-button.pvtv-button {
    min-width: 0;
}

/* Film facts block now also uses the shared panel class */
.pvtv-panel.pvtv-film-details-facts {
    padding: 1rem 1.1rem;
}

/* ========================================
   Fringe Flicks next event teaser
   ======================================== */

.pvtv-ff-next-event-teaser {
  display: grid;
  gap: 1.25rem;
}

.pvtv-ff-next-event-teaser__heading {
  margin: 0;
}

.pvtv-ff-next-event-teaser__media-column {
  display: grid;
  gap: 0.9rem;
  align-content: start;
}

.pvtv-ff-next-event-teaser__media {
  margin: 0;
}

.pvtv-ff-next-event-teaser__image-link {
  display: block;
  text-decoration: none;
}

.pvtv-ff-next-event-teaser__image {
  display: block;
  width: 100%;
  height: auto;
  border: 1px solid var(--pvtv-colour-border, #333);
}

.pvtv-ff-next-event-teaser__practical {
  display: grid;
  gap: 0.2rem;
}

.pvtv-ff-next-event-teaser__practical-date,
.pvtv-ff-next-event-teaser__practical-venue {
  margin: 0;
}

.pvtv-ff-next-event-teaser__practical-date {
  font-weight: 700;
}

.pvtv-ff-next-event-teaser__practical-venue {
  opacity: 0.88;
}

.pvtv-ff-next-event-teaser__content {
  display: grid;
  gap: 0.85rem;
  align-content: start;
}

.pvtv-ff-next-event-teaser__title {
  margin: 0;
  line-height: 1.05;
}

.pvtv-ff-next-event-teaser__title a {
  text-decoration: none;
}

.pvtv-ff-next-event-teaser__summary p {
  margin: 0;
}

.pvtv-ff-next-event-teaser__actions {
  margin-top: 0.1rem;
}

.pvtv-ff-next-event-teaser__fallback {
  margin: 0;
}

@media (min-width: 760px) {
  .pvtv-ff-next-event-teaser {
    grid-template-columns: minmax(260px, 1.05fr) minmax(260px, 0.95fr);
    align-items: start;
  }

  .pvtv-ff-next-event-teaser__heading {
    grid-column: 1 / -1;
  }
}



/* ========================================
   Fringe Flicks current season
   ======================================== */

.pvtv-ff-current-season {
  display: grid;
  gap: 1.25rem;
}

.pvtv-ff-current-season__heading,
.pvtv-ff-current-season__title,
.pvtv-ff-current-season__archive-heading {
  margin: 0;
}

.pvtv-ff-current-season__intro,
.pvtv-ff-current-season__events,
.pvtv-ff-current-season__archive {
  display: grid;
  gap: 0.75rem;
}

.pvtv-ff-current-season__title a,
.pvtv-ff-current-season__event-title a {
  text-decoration: none;
}

.pvtv-ff-current-season__summary p,
.pvtv-ff-current-season__empty-events,
.pvtv-ff-current-season__archive-text {
  margin: 0;
}

.pvtv-ff-current-season__event-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.85rem;
}

.pvtv-ff-current-season__event-item {
  padding-top: 0.85rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.pvtv-ff-current-season__event-item:first-child {
  padding-top: 0;
  border-top: 0;
}

.pvtv-ff-current-season__event-title {
  margin: 0 0 0.2rem;
  font-size: 1.05rem;
  line-height: 1.15;
}

.pvtv-ff-current-season__event-meta {
  margin: 0;
  opacity: 0.88;
}

.pvtv-ff-current-season__archive-text a {
  text-decoration: underline;
}

@media (min-width: 760px) {
  .pvtv-ff-current-season {
    grid-template-columns: minmax(260px, 0.95fr) minmax(280px, 1.05fr);
    align-items: start;
  }

  .pvtv-ff-current-season__heading,
  .pvtv-ff-current-season__archive {
    grid-column: 1 / -1;
  }
}

.pvtv-home-live-card {
    height: 100%;
    display: flex;
    flex-direction: column;
    background: #111;
    border: 1px solid #333;
    border-radius: 1.25rem;
    overflow: hidden;
}

.pvtv-home-live-card__image {
    aspect-ratio: 16 / 9;
    overflow: hidden;
}

.pvtv-home-live-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.pvtv-home-live-card__content {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    padding: 1.1rem;
}

.pvtv-home-live-card__label {
    margin: 0;
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    opacity: 0.8;
}

.pvtv-home-live-card__title {
    margin: 0;
    font-size: 1.4rem;
    line-height: 1.05;
}

.pvtv-home-live-card__text,
.pvtv-home-live-card__meta,
.pvtv-home-live-card__actions {
    margin: 0;
}

.pvtv-home-live-card__meta {
    font-size: 0.95rem;
    opacity: 0.8;
}

.pvtv-home-live-card__actions {
    margin-top: auto;
    padding-top: 0.4rem;
}

/* Generic labels */

.pvtv-card-labels {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.pvtv-card-label {
    display: inline-block;
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 0.45rem 0.55rem;
    border-radius: 999px;
    background: #222;
    border: 1px solid #444;
}

/* Films-specific light adjustment only where needed */

.pvtv-films-grid .pvtv-project-text {
    display: -webkit-box;
    -webkit-line-clamp: 9;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* =========================
   Mailchimp form
   ========================= */

.pvtv-mailing-list,
#mc_embed_signup {
  background: var(--pvtv-colour-panel);
  border: 1px solid var(--pvtv-colour-border);
  padding: 1.25rem;
  box-sizing: border-box;
  color: var(--pvtv-colour-text);
  max-width: 42rem;
}

.pvtv-mailing-list h2,
#mc_embed_signup h2 {
  margin: 0 0 0.75rem;
  color: var(--pvtv-colour-accent);
}

.pvtv-mailing-list__intro {
  margin: 0 0 1rem;
}

#mc_embed_signup .indicates-required {
  margin-bottom: 1rem;
  font-size: 0.95rem;
  opacity: 0.85;
}

#mc_embed_signup .asterisk {
  color: var(--pvtv-colour-accent);
}

#mc_embed_signup .mc-field-group {
  margin-bottom: 1.1rem;
}

#mc_embed_signup label,
#mc_embed_signup .input-group strong {
  display: block;
  margin-bottom: 0.45rem;
  font-weight: 700;
}

#mc_embed_signup input[type="email"],
#mc_embed_signup input[type="text"] {
  width: 100%;
  min-height: 44px;
  padding: 0.75rem 0.9rem;
  box-sizing: border-box;
  border: 1px solid var(--pvtv-colour-border);
  border-radius: var(--pvtv-radius);
  background: #111;
  color: var(--pvtv-colour-text);
}

#mc_embed_signup input[type="email"]::placeholder,
#mc_embed_signup input[type="text"]::placeholder {
  color: rgba(255,255,255,0.55);
}

#mc_embed_signup .input-group ul {
  list-style: none;
  margin: 0.6rem 0 0;
  padding: 0;
  display: grid;
  gap: 0.55rem;
}

#mc_embed_signup .input-group li {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
}

#mc_embed_signup input[type="checkbox"] {
  margin-top: 0.15rem;
  accent-color: var(--pvtv-colour-accent);
}

#mc_embed_signup .input-group label {
  margin: 0;
  font-weight: 400;
}

#mc_embed_signup .button,
#mc_embed_signup input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--pvtv-button-height);
  padding: 0.7rem 1.25rem;
  box-sizing: border-box;
  border: 1px solid var(--pvtv-colour-border);
  border-radius: var(--pvtv-radius);
  background: var(--pvtv-colour-accent);
  color: var(--pvtv-colour-text-dark);
  text-decoration: none;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  transition: background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}

#mc_embed_signup .button:hover,
#mc_embed_signup .button:focus,
#mc_embed_signup .button:focus-visible,
#mc_embed_signup input[type="submit"]:hover,
#mc_embed_signup input[type="submit"]:focus,
#mc_embed_signup input[type="submit"]:focus-visible {
  background: #fff;
  color: #111;
}

#mc_embed_signup .response {
  margin: 0.85rem 0 0;
  font-size: 0.95rem;
}

#mc_embed_signup .optionalParent {
  margin-top: 1.25rem;
}

@media (max-width: 640px) {
  .pvtv-mailing-list,
  #mc_embed_signup {
    padding: 1rem;
  }

  #mc_embed_signup .button,
  #mc_embed_signup input[type="submit"] {
    width: 100%;
    max-width: 20rem;
  }
}

.pvtv-ff-season-events {
    margin: 2rem 0;
}

.pvtv-ff-season-events__heading {
    margin: 0 0 1rem;
}

.pvtv-ff-season-events__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 1rem;
}

.pvtv-ff-season-events__item {
    padding: 1rem 0 0;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.pvtv-ff-season-events__item:first-child {
    padding-top: 0;
    border-top: 0;
}

.pvtv-ff-season-events__title {
    margin: 0 0 0.25rem;
    line-height: 1.1;
}

.pvtv-ff-season-events__title a {
    text-decoration: none;
}

.pvtv-ff-season-events__title a:hover,
.pvtv-ff-season-events__title a:focus,
.pvtv-ff-season-events__title a:focus-visible {
    text-decoration: underline;
}

.pvtv-ff-season-events__meta {
    margin: 0;
    opacity: 0.85;
}

.pvtv-ff-season-hero {
    margin: 0 0 2.5rem;
    background: #151515;
    border: 1px solid rgba(255, 255, 255, 0.08);
    overflow: hidden;
}

.pvtv-ff-season-hero__media img {
    display: block;
    width: 100%;
    height: auto;
    max-height: 70vh;
    object-fit: cover;
}

.pvtv-ff-season-hero__content {
    padding: 1.25rem;
}

.pvtv-ff-season-hero__title {
    margin: 0 0 0.75rem;
    line-height: 1;
}

.pvtv-ff-season-hero__summary {
    margin: 0 0 1rem;
    font-size: 1.05rem;
    line-height: 1.5;
    max-width: 48rem;
}

.pvtv-ff-season-hero__meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 2rem;
    row-gap: 1rem;
}

.pvtv-ff-season-hero__meta-item {
    display: block;
}

@media (max-width: 640px) {
    .pvtv-ff-season-hero__meta {
        grid-template-columns: 1fr;
    }
}

.pvtv-ff-film-card-country {
    margin: 0 0 0.45rem;
    font-size: 0.92rem;
    opacity: 0.82;
}

/* Shared tight stacked meta treatment
   Use for label/value pairs where the uppercase label
   needs to sit visually close to the value beneath it. */
.pvtv-meta-stack-tight {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
}

.pvtv-meta-stack-tight .pvtv-meta-label {
    margin-top: 1.5rem;
    margin-bottom: 0;
}

.pvtv-meta-stack-tight .pvtv-meta-value {
    margin-top: -1.25rem;
    margin-bottom: 0;
}
