/* cf-vars.css */
:root {
  --color-yellow: #E7FF7A;
  /*--color-orange: #EB8C35;*/
  --color-orange: #F26726;
  --color-lime: #e7ff7a;
  --color-lime-wash: #f3f8d1;
  /*--color-green: #539e78;*/
  --color-green: #C1E304;
  --color-blue: #46a5e5;
  /*--color-blue-green: #5D9E79;*/
  --color-blue-green: #C1E304;
  --color-blue-grey: #415063;
  --color-navy: #0b344f;
  --color-text-body: #CBD0CC;
  --color-links: #E7FF7A;
  --color-links-hover: #F16325;
  --color-heading: #E7FF7A;
  --color-tab-active: #E7FF7A;

  --mobile-menu-height: 105px;
  --padding-container-outer: 30px;
  --gradient-bg: linear-gradient( to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.15) 25%, rgba(0, 0, 0, 0.45) 50%, rgba(0, 0, 0, 0.75) 75%, rgba(0, 0, 0, 0.95) 100% );
}

@media (min-width:782px) {
  :root {
    --padding-container-outer: 80px;
  }
}

/* cf-global.css */
body {
  background: #112339;
  color: white;
  font-size: 1.2rem;
  font-family: "Barlow", sans-serif;
}
h1, h2, h3, h4, h5, h6 {
  text-transform: uppercase;
  font-weight: 900;
  color: var(--color-heading);
  margin: 0;
}
h3, h4, h5, h6 {
  font-weight: 700;
}
p {
  font-size: 1.6rem;
  color: var(--color-text-body);
}
li {
  color: var(--color-text-body);
}
a {
  color: var(--color-links);
  transition: color 0.3s ease;
}
a:hover {
  color: var(--color-links-hover);
}
button, .button {
  font-weight: bold;
  background-color: var(--color-links);
  padding: 0.5em 1em;
  font-size: 1.3rem;
  border: 0;
  font-family:"Barlow", sans-serif;
  cursor: pointer;
  transition: background-color 0.3s ease;
  color: black;
}
button:hover, .button:hover {
  background-color: var(--color-links-hover);
}
button[disabled],
.button-done {
  background-color: var(--color-links-hover);
}
header.wp-block-template-part {
  background: linear-gradient(#000000, transparent);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 20;
}
header .cfmdc-logo {
  width: 275px;
}
header .cfmdc-logo a {
  display: block;
  width: 100%;
}
header .cfmdc-logo img {
  display: block;
  width: 100%;
}
main {
  margin-top: 0;
  position: relative;
  z-index: 1;
}
.cfmdc-header-actions :is(.cfmdc-header-actions--search, .cfmdc-header-actions--login) {
  display: none;
}
.cfmdc-header-actions :is(button, a) {
  background: transparent;
  color: var(--color-orange);
  font-weight: bold;
  text-transform: uppercase;
  border: 0px;
  /* border-bottom: 1px solid var(--color-orange); */
  padding: 0.5rem;
  text-decoration: none;
  margin-right: 10px;
}
.page-template-default .default-page-title {
  display: none;
}
.page-template-default .wp-block-post-title {
  color: var(--color-lime-wash);
  font-family: "Barlow", sans-serif;
  text-transform: uppercase;
}
main .wp-element-button {
  background-color: var(--color-lime);
  border-radius: 0;
  color: black;
  text-transform: uppercase;
  font-family: "Barlow", sans-serif;
  font-weight: bold;
}
input, textarea, select {
  font-family: "Barlow", sans-serif;
}
.wp-block-post-content>:is(p,
.wp-block-heading,
.wp-block-list,
.wp-block-spacer,
.wp-block-group,
.wp-block-buttons,
.wp-block-accordion,
.wp-block-columns,
.wp-block-gallery,
.cf-form) {
  padding-left: var(--padding-container-outer);
  padding-right: var(--padding-container-outer);
}
.wp-block-list li {
  margin-left: var(--wp--preset--spacing--50);
}

.wp-block-table thead {
  border: 0;
}
.wp-block-table th {
  text-align: left;
  text-transform: uppercase;
  color: var(--color-lime-wash);
  font-weight: bold;
  font-size: 1.22rem;
}
.wp-block-table td, .wp-block-table th {
  border: 0;
  border-bottom: 1px solid var(--color-blue-green);
  font-family: "Barlow", sans-serif;
  text-transform: uppercase;
  font-weight: bold;
}
.wp-block-table td:first-child {
  color: var(--color-blue-green);
}
.wp-block-accordion-heading__toggle-title {
  flex: unset;
}

/* Content Univeral Styles */
.entry-content h1.wp-block-heading {
  font-size: 5.0rem;
  margin-bottom: 3rem;
}
.entry-content h2.wp-block-heading {
  font-size: 2.7rem;
}
.entry-content h3.wp-block-heading {
  font-size: 1.8rem;
}
/* TEMP */
.page-id-153297 h1.wp-block-heading {
  font-size: 3rem;
  text-transform: uppercase;
  color: var(--color-lime);
}
.page-id-153297 h2.wp-block-heading {
  font-family: "Barlow", sans-serif;
  font-size: 2.5rem;
  text-transform: uppercase;
  color: var(--color-blue-green);
}

.wp-block-accordion-heading__toggle-title,
.wp-block-accordion-heading__toggle-icon {
  font-family: "Barlow", sans-serif;
  font-size: 2rem;
  text-transform: uppercase;
  color: var(--color-blue-green);
}
.page-id-153297 p {
  color: white;
  font-size: 1.2rem;
}

@media (min-width: 600px) and (max-width: 1199px) {
    ul.wp-block-post-template.columns-3.is-layout-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}
@media (max-width: 781px) {
  .wp-site-blocks {
    padding-top: 50px;
  }
}


/* cf-footer.css */
footer.wp-block-template-part {
  display: none !important;
}
.cf-newsletter-footer {
  z-index: 1;
  position: relative;
  padding: var(--wp--preset--spacing--60) var(--padding-container-outer);
}
.cf-newsletter-footer h6 {
  text-transform: none;
  font-size: 1.4rem;
  margin-bottom: 20px;
}
.cf-newsletter-footer label {
  display: none;
}
.cf-newsletter-footer .cf-field {
  display: block;
}
.cf-sitemap {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template: auto / 1fr;
  padding: var(--wp--preset--spacing--60) var(--padding-container-outer);
  grid-gap: 10px;
}
.cf-sitemap ul {
  list-style: none;
  padding: 0;
  margin: 20px 0;
}
.cf-sitemap h6 a {
  color: var(--color-heading);
  text-transform: none;
  font-size: 1.4rem;
  padding: 0;
}
.cf-sitemap a {
  color: var(--color-text-body);
  text-decoration: none;
  display: block;
  padding: 0 0 0.5em 0;
}
.page-template-page-accordion :is(.cf-sitemap, .cf-newsletter-footer) {
  display: none;
}
@media (min-width: 600px) {
  .cf-sitemap {
    grid-template: auto / 1fr 1fr;
    padding-right: 0;
  }
  .cf-newsletter-footer {
    padding-left: 0;
  }
}
@media (min-width: 782px) {
  footer {
    display: grid;
    grid-template: auto / 83vw 17vw;
  }

  .cf-sitemap {
    grid-template: auto / 1fr 1fr 1fr 1fr;
  }
  .cf-sitemap [data-slug="engagement"] {
    grid-column: 1/2;
    grid-row: 2/5;
  }
  .cf-sitemap [data-slug="about"] {
    grid-column: 2/3;
    grid-row: 2/5;
  }
  .cf-sitemap [data-slug="whats-on"] {
    grid-column: 3/4;
    grid-row: 2/3;
  }
  .cf-sitemap [data-slug="shop"] {
    grid-column: 3/4;
    grid-row: 3/4;
  }
  .cf-sitemap [data-slug="order-request"] {
    grid-column: 3/4;
    grid-row: 4/5;
  }
  .cf-newsletter-footer {
    z-index: 1;
    position: relative;
    padding-right: var(--padding-container-outer);
  }

}
@media (min-width: 1280px) {
  .cf-sitemap {
    grid-template: auto / repeat(7, 1fr);
  }
  .cf-sitemap>div {
    grid-row: 1/4;
  }
  .cf-sitemap [data-slug="engagement"] {
    grid-column: 5/6;
    grid-row: 1/4;
  }
  .cf-sitemap [data-slug="about"] {
    grid-column: 6/7;
    grid-row: 1/4;
  }
  .cf-sitemap [data-slug="whats-on"] {
    grid-column: 7/8;
    grid-row: 1/2;
  }
  .cf-sitemap [data-slug="shop"] {
    grid-column: 7/8;
    grid-row: 2/3;
  }
  .cf-sitemap [data-slug="order-request"] {
    grid-column: 7/8;
    grid-row: 3/4;
  }
}

/* cf-social.css */
.cf-social-links {
  --social-transition: 0.3s;
  list-style: none;
  display: flex;
  justify-content: flex-end;
  position: fixed;
  right: -50px;
  z-index: -1;
  bottom: 0;
  width: 100vw;
  margin: 0;
  padding:0;
  opacity: 0;
  transition: right var(--social-transition) ease, opacity var(--social-transition) ease, z-index 0s ease var(--social-transition);
}
.cf-social-links.active {
  right: 65px;
  opacity: 1;
  z-index: 2;
  transition: right var(--social-transition) ease, opacity var(--social-transition) ease, z-index 0s ease;
}
.cf-social-links a {
  text-decoration: none;
  margin: 0 0.35em;
  padding: 0.55em 0;
  display: block;
  transition: transform var(--social-transition) ease;
}
.cf-social-links a:hover {
  transform: scale(1.45, 1.45);
}
.cf-social-links [class*="fa-"] {
  background: var(--color-green);
  color: black;
  border-radius: 100px;
  width: 3rem;
  height: 3rem;
  display: flex;
  justify-content: center;
  align-items: center;
}
:is(.cf-social-links, .cf-social-toggle) [class*="fa-"]::before {
  font-size: 1.6rem;
}
.cf-social-links .cf-social-text {
  display: none;
}
.cf-social-toggle {
  padding: 0.55em 0.75em;
  position: fixed;
  bottom: 0.5em;
  right: 0;
  z-index: 3;
  background-color: var(--color-green);
}
/*
@media (orientation: portrait) {
  .cf-social-toggle {
    padding: 0.35em 0.6em;
  }
  :is(.cf-social-links, .cf-social-toggle) [class*="fa-"]::before {
    font-size: 1.2rem;
  }
  .cf-social-links [class*="fa-"] {
    height: 2.5rem;
    width: 2.5rem;
  }
  .cf-social-links.active {
    right: 50px;
  }
  .cf-social-links a {
    margin: 0 0.2em;
  }
}
*/
@media (orientation: portrait) {

  .cf-social-links {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0 !important;
    width: 100vw;
    height: 100vh;
    max-width: 100vw;
    background-color: transparent;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    margin-left: 0;
    margin-right: 0;
    gap: 1rem;
    padding: 60% 25%;
    box-sizing: border-box;
    opacity: 0;
    z-index: -1;
    transition: background-color var(--social-transition) ease, opacity var(--social-transition) ease, z-index 0s ease var(--social-transition);
  }

  .cf-social-links.active {
    right: 0 !important;
    background-color: rgba(0, 0, 0, 0.75);
    /* Need full viewport again for the overlay */
    max-width: 100vw;
    opacity: 1;
    z-index: 2;
    transition: background-color var(--social-transition) ease, opacity var(--social-transition) ease, z-index 0s ease;
  }

  .cf-social-links.active li {
    flex: 0 0 auto;
    display: flex;
    justify-content: center;
  }

  .cf-social-links a {
    margin: 0;
  }
}

/* cf-nav.css */
/* Menu */
.wp-block-navigation__responsive-container-open:hover,
.wp-block-navigation__responsive-container-close:hover {
  background: transparent !important;
  color: inherit !important;
}
.wp-block-navigation__responsive-container-close svg,
.wp-block-navigation__responsive-container-open svg {
  color: var(--color-links-hover);
  transition: color 0.5s ease;
}
.wp-block-navigation__responsive-container-close:hover svg,
.wp-block-navigation__responsive-container-open:hover svg {
  color: var(--color-links);
}
.wp-block-navigation__responsive-container-close {
  top: 1rem;
  right: 1rem;
}
.wp-block-navigation-item {
  width:100%;
}

.wp-block-navigation .wp-block-navigation-item__content.wp-block-navigation-item__content:hover {
  color: var(--color-yellow);
}
.wp-block-navigation .wp-block-navigation-item__content.wp-block-navigation-item__content {
  color: var(--color-green);
  font-weight: bold;
  text-align: right;
  display: block;
  width: 100%;
  font-size: 2rem;
  padding-bottom: 15px !important;
  outline-offset: 0 !important;
  outline-width: 0 !important;
  border-bottom: 1px solid var(--color-green);
  transition: color 0.3s ease;
}
/*
.wp-block-navigation .wp-block-navigation-item.current-menu-ancestor.wp-block-navigation-item__content.wp-block-navigation-item__content,
.wp-block-navigation .wp-block-navigation-item.current-menu-ancestor .wp-block-navigation-item__content,
.wp-block-navigation .wp-block-navigation-item.current-menu-item.wp-block-navigation-item__content.wp-block-navigation-item__content,
.wp-block-navigation .wp-block-navigation-item.current-menu-item .wp-block-navigation-item__content {
  color: var(--color-text-body);
}
*/
.wp-block-navigation .wp-block-navigation-item.current-menu-ancestor .wp-block-navigation__submenu-container .wp-block-navigation-item__content,
.wp-block-navigation .wp-block-navigation-item.current-menu-item .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
  color: var(--color-text-body);
}
.wp-block-navigation .wp-block-navigation-item.current-menu-ancestor>.wp-block-navigation__submenu-container,
.wp-block-navigation .wp-block-navigation-item.current-menu-item>.wp-block-navigation__submenu-container {
  display: block !important;
}
.wp-block-navigation .wp-block-navigation-item .wp-block-navigation__submenu-container {
  padding: 0 !important;
  box-sizing: border-box !important;
  width: 100% !important;
  display: none !important; /* disable for now */
}
.wp-block-navigation .wp-block-navigation-item .wp-block-navigation__submenu-container .wp-block-navigation-item {
}
.wp-block-navigation .wp-block-navigation-item .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
  display: block !important;
  box-sizing: border-box;
  font-weight: normal !important;
  font-size: 1.5rem;
}
#modal-1 {
  background-color: rgba(0,0,0, 0.5) !important;
}

#modal-1 .wp-block-navigation__container{
  width: 100%;
}
#modal-1 .wp-block-navigation__responsive-close {
  position: relative;
}
#modal-1 .wp-block-navigation__responsive-dialog {
  width: 400px;
  background-color: rgba(11, 52, 79, 0.9);
  position: fixed;
  top: 0px;
  right: 0px;
  bottom: 0px;
  padding: 20px;
  margin-top: 0;
  overflow-y: auto;
}
#modal-1-content {
  padding-top: 2rem !important;
}

@media (max-width: 781px) {
  #modal-1 .wp-block-navigation__responsive-dialog {
    width: 100vw;
  }
  .wp-block-navigation .wp-block-navigation-item__content.wp-block-navigation-item__content {
    text-align: center;
  }
}

/* cf-dynamic-panel.css */
.cf-dynamic-panel {
  display: none;
}
.cf-dynamic-panel.active {
  display: block;
}

/* cf-drop-down.css */
/* CF drop down */


/* ── Variables ── */
.cf-drop-down {
  --text: #1f2937;
  --accent: #2563eb;
  --hover-bg: #eff6ff;
  --shadow: 0 4px 16px rgba(0, 0, 0, 0.10);
  --radius: 8px;

  position: relative;
  display: inline-block;
}
.cf-drop-down {
  --text: black;
  --accent: #2563eb;
  --hover-bg: #EB8C35;
  --shadow: 0 4px 16px rgba(0, 0, 0, 0.10);
  --radius: 0px;
}

/* ── Hide the checkbox visually ── */
.cf-drop-down--activate {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}

/* ── Label acts as the visible button ── */
.cf-drop-down label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-width: 50px;
  padding: 10px 14px;
  background: var(--color-green);
  border: 1.5px solid var(--color-green);
  border-radius: var(--radius);
  color: var(--text);
/*  font-size: 0.95rem; */
  cursor: pointer;
  user-select: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}

/* ── Arrow via pseudo-element ── */
.cf-drop-down label.cf-drop-down--current {
  font-weight: bold;
}
.cf-drop-down label.cf-drop-down--current::after {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-right: 2px solid var(--text);
  border-bottom: 2px solid var(--text);
  transform: rotate(45deg) translateY(-2px);
  transition: transform 0.2s;
  flex-shrink: 0;
}

.cf-drop-down label.cf-drop-down--current:hover {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.15);
}

.cf-drop-down .cf-drop-down--reset label {
  /* font-size: 1rem; */
  font-weight: bold;
  font-style: normal;
  color: black;
}

/* ── Dropdown list — hidden by default ── */
.cf-drop-down ul {
  position: absolute;
  max-height: 500px;
  overflow-y: auto;
  top: calc(100% + 6px);
  left: 0;
  min-width: 100%;
  margin: 0;
  padding: 6px;
  list-style: none;
  background: var(--color-green);
  border: 1.5px solid var(--color-green);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  z-index: 100;

  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s;
}

/* ── Open state ── */
.cf-drop-down--activate:checked ~ ul {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* ── Flip arrow when open ── */
.cf-drop-down--activate:checked ~ label::after {
  transform: rotate(225deg) translateY(-2px);
}

/* ── List items ── */
.cf-drop-down li {
  border-radius: calc(var(--radius) - 2px);
}
.cf-drop-down li input {
  display: none;
}

.cf-drop-down li :is(a, label) {
  display: block;
  padding: 9px 1em;
  color: var(--text);
  text-decoration: none;
/*  font-size: 0.95rem; */
  border-radius: calc(var(--radius) - 2px);
  white-space: nowrap;
  transition: background 0.15s, color 0.15s;
}

.cf-drop-down li :is(a, label):hover {
  background: var(--hover-bg);
  color: var(--accent);
}

/* cf-fields.css */
.cf-radio-list--heading {
  font-weight: bold;
}
.cf-radio-list ul li {
  display: inline-block;
  margin-right: 1em;
  padding: 0.5em 0;
}
.cf-radio-list ul li input {
  display: inline-block;
  margin-right: 0.75em;
}

.cf-tag-list--heading {
  font-weight: bold;
}
.cf-tag-list ul li {
  display: inline-block;
  margin-right: 0.5em;
}
.cf-tag-list li input {
  display: none;
}
.cf-tag-list li input:checked + label {
  background: rgba(255,255,255, 1);
  border: 1px solid black;
}
.cf-tag-list li label {
  background: rgba(255,255,255, 0.8);
  display: block;
  padding: 0.5em;
  border: 1px solid white;
}

/* cf-form.css */
.cf-field>label {
  text-transform: uppercase;
  color: var(--color-green);
  font-family: "Barlow", sans-serif;
  font-weight: bold;
  font-size: 1.4rem;
  padding: 0.5em 1em 0.5em 0;
}
.cf-field :is(textarea, select,
  [type="text"],
  [type="email"],
  [type="number"]
) {
  background: var(--color-blue-grey);
  padding: 0.5em 1em;
  color: white;
  border: 0;
  font-size: 1.4rem;
  font-family: 'Barlow', sans-serif;
}
.cf-section-label {
  color: var(--color-heading);
  text-transform: uppercase;
  font-family: "Barlow", sans-serif;
  font-size: 2rem;
  font-weight: 900;
}
.cf-field--info {
  background: transparent !important;
  color: white;
  padding:0;
  margin: 0 0.2em;
  color: var(--color-links);
  transition: color 0.3s ease;
}
.cf-field--info:hover {
  color: var(--color-links-hover);
}
.cf-field fieldset {
  border: 0;
  padding: 0;
  margin: 0;
}
.cf-checkbox-option {
  color: white;
  margin-bottom: 1em;
}

.cf-form-success {
  font-size: 2.0rem;
  font-weight: 900;
  color: var(--color-heading);
  text-align: center;
  text-transform: uppercase;
  padding: 0 var(--padding-container-outer);
}

.cf-field--description--modal {
  background: var(--color-navy);
  border: 1px solid white;
}
.cf-field--description--content {
  color: white;
}
.cf-field--description--close {
  color: white;
}

.cf-tags [type="checkbox"]:checked + .cf-tag {
  color: var(--color-navy);
  border-color: var(--color-links-hover);
  background: var(--color-links-hover);
}

.cf-field-checkbox_list[data-slug="shipping_is_different_from_billing"] .cf-checkbox-list {
  column-count: 1;
}

.cf-form--info-modal--container {
  background: var(--color-navy);
  border: 1px solid white;
}
.cf-form--error-modal .cf-form--info-modal--container {
  width: fit-content;
  height: fit-content;
  min-width: 20vw;
  text-align: center;
}

/* cf-accordion.css */
.tab-text {
  text-transform: uppercase;
/*
  border-top-left-radius: 20px;
  border-bottom-left-radius: 20px;
*/
  box-shadow: inset -10px 0px 15px rgba(0, 0, 0, 0.5);
  border-width:0;
  font-family: "Barlow", sans-serif;
  font-weight: bold;
}
.slider-film-background {
  position: relative;
  width: 100%;
  height: 100vh;
  background: black;
  overflow: hidden;
}
.slider-film-background iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); /* Keeps the video centered during resizing */
  
  width: 100%;
  height: 100%;
  aspect-ratio: 16 / 9;

  /* The Logic: */
  /* If the container is wider than 16:9, scale by width */
  min-width: 133.33vh; 
  /* If the container is taller than 16:9 (Portrait), scale by height */
  min-height: 75vw; 
  
  /* Modern Browser fallback to ensure it covers the area */
  width: max(100%, 133.33vh);
  height: max(100%, 75vw);
}
.slider-film-background .slider-film-caption {
  position: absolute;
  margin: 0;
  bottom: 0;
  left:0;
  right: 0;
  padding: 12rem 1rem 150px 3rem;
  font-family: "Barlow", sans-serif;
  font-size: 2rem;
  font-weight: bold;
  text-transform: uppercase;
  background: linear-gradient( to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.15) 25%, rgba(0, 0, 0, 0.45) 50%, rgba(0, 0, 0, 0.75) 75%, rgba(0, 0, 0, 0.95) 100% );
}
.accordion-tab button {
  background: var(--color-navy);
  color: var(--color-green);
  transition: color 1s ease;
}
.active .accordion-tab button {
  color: var(--color-tab-active);
}
@media (orientation: portrait) {
  .page-template-page-accordion main#wp--skip-link--target {
    margin-top: var(--mobile-menu-height) !important;
    height: calc(100vh - var(--mobile-menu-height));
  }
  .page-template-page-accordion .wp-site-blocks {
    padding-top: var(--wp--style--root--padding-top);
  }
  .accordion-container.full-screen {
    height: calc(100vh - var(--mobile-menu-height));
  }
  .accordion-item.active:first-child {
    height: inherit;
  }
  .accordion-item.active:first-child :is(.accordion-content, .content-inner, .slider-film-background) {
    height: 100%;
  }
}

/* cf-theatre.css */
.header-theatre {
  position: relative;
  overflow: hidden;
  margin-bottom: var(--wp--preset--spacing--60);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  color: white;
}
.header-theatre .wp-block-post-title {
  padding: 0 var(--wp--preset--spacing--60);
  font-weight: bold;
  position: relative;
  z-index: 1;
}
.film-player {
  background: black;
}
.film-player iframe {
  width: 100%;
  height: 100%;
  aspect-ratio: 16 / 9;
}
.film-player img.film-thumbnail {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (orientation: landscape) and (min-width: 782px) {
  .header-theatre {
    min-height: 80vh;
  }
  .film-player {
    position: absolute;
    top:0;
    left:0;
    right:0;
    bottom:0;
  }
  .film-player iframe {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); /* Keeps the video centered during resizing */


    /* The Logic: */
    /* If the container is wider than 16:9, scale by width */
    min-width: 133.33vh;
    /* If the container is taller than 16:9 (Portrait), scale by height */
    min-height: 75vw;

    /* Modern Browser fallback to ensure it covers the area */
    width: max(100%, 133.33vh);
    height: max(100%, 75vw);
  }
  .film-player img.film-thumbnail {
    position: absolute;
    top: 0;
    left: 0;
  }

}
.film-block-details {
  position: relative;
  padding-bottom: var(--wp--preset--spacing--60);
  background: linear-gradient(transparent, rgba(0,0,0, 0.5), rgba(0,0,0,0.81), rgba(0,0,0,1));
}
.film-block-details .entry-content p {
  padding: 0;
}
.film-meta {
  display: grid;
  grid-template: auto / 150px auto;
}
.film-meta strong {
  font-weight: bold;
}
/* Page Theatre */
.page-template-default .header-theatre .wp-theatre-data {
  position: absolute;
  width: 100%;
  bottom: 0;
  box-sizing: border-box;
  padding: var(--wp--preset--spacing--50) var(--padding-container-outer) var(--wp--preset--spacing--20) var(--padding-container-outer);
  background: linear-gradient(rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.15) 25%, rgba(0, 0, 0, 0.45) 50%, rgba(0, 0, 0, 0.75) 75%, rgba(0, 0, 0, 0.95) 100%);
}
.page-template-default .header-theatre .wp-theatre-title {
  padding: 0;
  font-size: 48px;
  font-family: "Barlow", sans-serif;
  font-weight: 700;
  text-transform: uppercase;
}
.page-template-default .header-theatre .wp-theatre-caption {
  margin-top: 0;
  padding: inherit;
}

/* cf-carousel.css */
.cf-carousel {
  padding-left: var(--carousel--padding);
  padding-right: var(--carousel--padding);
}
button[data-direction] {
  background: transparent !important;
}
button[data-direction]:active,
button[data-direction]:focus {
  outline: 1px solid var(--color-links-hover);
}
button[data-direction]::before {
  background: transparent;
  color: var(--color-links);
  transition: color 0.3s ease;
}
button[data-direction]:hover::before {
  color: var(--color-links-hover);
}
.cf-carousel--post-title {
  font-family: 'Barlow', sans-serif;
  font-weight: bold;
  color: var(--color-heading);
  text-transform: uppercase;
}


/* cf-image-list.css */
.image-list {
  padding-left: var(--padding-container-outer);
  padding-right: var(--padding-container-outer);
}
.image-list ul {
  grid-gap: 20px;
  list-style: none;
  padding-left: 0;
}
.image-list--item {
	padding: 0;
}
.image-list--thumbnail {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
  aspect-ratio: 4/3;
}

.image-list--thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.image-list--thumbnail .image-list--label {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--gradient-bg); 
/*
  background:linear-gradient(
  to bottom,
  rgba(0, 0, 0, 0) 0%,
  rgba(0, 0, 0, 0.03) 18%,
  rgba(0, 0, 0, 0.12) 36%,
  rgba(0, 0, 0, 0.29) 54%,
  rgba(0, 0, 0, 0.52) 72%,
  rgba(0, 0, 0, 0.73) 88%,
  rgba(0, 0, 0, 0.85) 100%
  );
*/
  color: var(--text-color);
  display: block;
  padding: 3em 1em 0.5em 1em;
  font-family: 'Barlow', sans-serif;
  font-weight: bold;
  text-transform: uppercase;
  font-size: 1.4rem;
}
/*
@media (max-width: 599px) {
  .image-list--thumbnail .image-list--label {
    font-size: 1.2rem;
  }
}
*/

/* cf-home.css */
.home .wp-block-post-title {
  display: none;
}
.home main {
  margin: 0 !important;
}

/* cf-film.css */
.films-stills {
  --films-stills--padding: 40px;
}
.films-stills>* {
  padding: 0 var(--films-stills--padding);
}
:is(.films-stills, .films-related) ul {
  list-style: none;
  display: grid;
  grid-template: auto / repeat(4, 1fr);
  grid-gap: 10px;
}
/* Film */
.single-film {
  color: white;
}
.single-film .cf-qty-value {
  display: none;
}
.cf-film-back {
  padding: 0 var(--padding-container-outer);
  position: relative;
  z-index: 1;
}
.cf-film-back button {
  font-size: 1rem;
}
@media (orientation: landscape) and (min-width: 782px) {
  .single-film .header-theatre .wp-block-post-title {
    padding: 160px var(--wp--preset--spacing--60) 0 var(--wp--preset--spacing--60);
  }
}
@media (max-width: 1279px) {
  :is(.films-stills, .films-related) ul {
    grid-template: auto / repeat(2, 1fr);
  }
}
@media (max-width: 599px) {
  :is(.films-stills, .films-related) ul {
    grid-template: auto / 1fr;
  }
}

/* cf-film-search.css */
.page-template-archive-film {
  color: white;
}
.film-search--block {
  margin-top: 0;
  padding: 0 var(--wp--preset--spacing--60);
}
.film-search--top-line {
  padding: 2rem 0 1rem 0;
}
#q-mobile {
  width: 100%;
  box-sizing: border-box;
}
#q {
  display: none;
}
.cf-q {
  background: var(--color-green);
  border: 0;
  padding: 0.7em 14px;
  font-size: 1.2rem;
  font-weight:bold;
}
.cf-q::placeholder {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: var(--text);
  font-size: 1.2rem;
  font-weight:bold;
}
.film-search--filter {
  font-weight: bold;
  display: inline-block;
  margin-top: 0.5em;
  cursor: pointer;
}
.film-search--filter .fa-solid {
  font-size: 0.8em;
  margin-right: 0.5em;
}
.film-search--filter:hover {
  color: var(--color-links-hover);
}

#film-search--options-enable {
  display: none;
}
#film-search--options-enable:checked ~ .film-search--options {
  display: block;
}
.film-search--options {
  display: none;
  background-color: rgba(255,255,255, 0.5);
  padding: 0.5rem;
}
.film-search--options ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.film-search--options .cf-drop-down {
  margin-bottom: 0.2em;
}
.film-search--formats--heading {
  font-weight: bold;
}
.film-search--actions {
}
.film-search--actions .film-search--clear-filters {
  font-weight: bold;
  text-decoration: none;
  margin-right: 1em;
  position: relative;
  padding-left: 1em;
}
.film-search--actions button[type="submit"] {
  font-size: 1.3rem;
  padding: 0.55em 1em;
}
.film-search--actions .film-search--clear-filters::before {
  content: '\00D7';
  position: absolute;
  top: -0.3em;
  left: 0;
  font-size: 1.2em;
}
.film-search--note {
  text-align: center;
}
@media (min-width: 600px) {
  .page-template-archive-film .wp-block-post-title {
    font-size: 4.2rem;
  }
  .film-search--filter {
    display: none;
  }
  .film-search--top-line {
    display: none;
  }
  .film-search--options {
    display: flex;
    padding: 2rem 0 0.2rem 0;
    width: 100%;
    flex-wrap: wrap;
    background: transparent;
    align-items: center;
    justify-content: flex-end;
  }
  .film-search--options :is(.cf-drop-down, [type="text"]) {
    margin: 0 0 0.5em 1em;
  }
  .film-search--actions {
    margin-bottom: 0.5em;
  }
  #q {
    display: block;
    min-width: 300px;
  }
}

/* cf-film-maker.css */
.page-template-single-film-maker {
  color: white;
}
.page-template-single-film-maker .header-theatre .wp-block-post-title {
  padding-left:var(--padding-container-outer);
  padding-right:var(--padding-container-outer);
}
@media (orientation: landscape) and (min-width: 782px) {
  .page-template-single-film-maker .header-theatre .wp-block-post-title {
    padding-top: 160px;
  }
}
/* TEMP: Disable headshot */
.page-template-single-film-maker .header-theatre {
  justify-content: flex-start;
  margin-bottom: var(--wp--preset--spacing--50);
  min-height: fit-content;
}
.page-template-single-film-maker .film-player {
  display: none;
}
.page-template-single-film-maker .header-theatre .wp-block-post-title {
  padding-top: 160px;
  margin-bottom: 1em;
}
.page-template-single-film-maker .header-theatre .film-block-details {
  font-size: 1.4rem;
}
@media (orientation: portrait) {
  .page-template-single-film-maker .header-theatre .wp-block-post-title {
    padding-top: 100px;
    margin-bottom: 1em;
  }
  .page-template-single-film-maker .header-theatre .wp-block-post-title {
    margin-bottom: 0;
  }
}

/* TEMP: END */

/* cf-newsletter.css */
.cf-newsletter {
  padding: var(--wp--preset--spacing--60) var(--padding-container-outer) 110px var(--padding-container-outer);
  background: var(--color-blue-grey);
  text-align: center;
  margin-bottom: var(--wp--preset--spacing--50);
}
.cf-newsletter h6 {
  font-size: 2.7rem;
  text-transform: uppercase;
  font-weight: 900;
  margin: 0;
}
#newsletter_success {
  text-align: left;
  padding: 0;
}

/* cf-timeline.css */

.cf-timeline {
  width: 100%;
  box-sizing: border-box;
  margin: 0 auto;
/*  padding: 0 var(--padding-container-outer); */
  --middle-gap: 30px;
}
.cf-timeline-item {
  box-sizing: border-box;
}
.cf-timeline-item img {
  width: 100%;
  height: auto;
}
.cf-timeline-item h3 {
  color: var(--color-green);
  font-size: 2rem;
  margin-bottom: 1em;
  text-transform: unset;
}

@media (min-width: 782px) {
  .cf-timeline-item {
    width: 50%;
    float: left;
    box-sizing: border-box;
    padding-right: var(--middle-gap);
  }
  .cf-timeline-item:nth-child(even) {
    float: right;
    padding-left: var(--middle-gap);
    padding-right: 0;
  }
}

/* cf-cart.css */
.cf-cart table {
  width: 100%;
  border-collapse: collapse;
  font-size: 1.4rem;
  margin-bottom: 1rem;
}
.cf-cart :is(td, th) {
  text-align: left;
  padding: 0.5em 1em;
}
.cf-cart th {
  text-transform: uppercase;
  color: var(--color-green);
}
.cf-cart :is(td, th):first-child {
  padding-left: 0;
}
.cf-cart .cf-qty-value {
  display: none;
}
.cf-cart .cf-row-film [name^="items"] {
  display: none;
}
.cf-cart .cf-row-film .cf-qty-value {
  display: block;
}
.cf-product a {
  text-decoration: none;
  color: var(--color-text-body);
}
.cf-product a:hover {
  text-decoration: underline;
  color: var(--color-link-hover);
}

