/* Set global custom properties */

:root {
  --measure: 60ch;
  font-size: 1rem; /* Set base font size to scale with viewport (browser) width */
  --ratio: 1.15; /* Specify a ratio as the basis for modular scale of headings */
  --font-multiplier: 1rem;

  --s-6: calc(var(--s-5) / var(--ratio));
  --s-5: calc(var(--s-4) / var(--ratio));
  --s-4: calc(var(--s-3) / var(--ratio));
  --s-3: calc(var(--s-2) / var(--ratio));
  --s-2: calc(var(--s-1) / var(--ratio));
  --s-1: calc(var(--s0) / var(--ratio));
  --s0: calc(1 * var(--font-multiplier)); /* 15pt / 16 */
  --s1: calc(1.0625 * var(--font-multiplier)); /* 17pt / 16 */
  --s2: calc(1.25 * var(--font-multiplier)); /* 20pt / 16 */
  --s3: calc(1.5 * var(--font-multiplier)); /* 24pt / 16 */
  --s4: calc(1.625 * var(--font-multiplier)); /* 26pt / 16 */
  --s5: calc(1.875 * var(--font-multiplier)); /* 30pt / 16 */
  --s6: calc(2.25 * var(--font-multiplier)); /* 36pt / 16 */
  --s7: calc(2.5 * var(--font-multiplier)); /* 40pt / 16 */

  --wp--preset--font-size--large: var(--s3);

  --displayfont-spacing: .1ch;

  --clr00: #ffffff;
  --clr01: #000000;
  --clr01t: rgb(26,26,26);
  --clr01b: #2b2b2b;
  --clr02: rgba(230,230,230,1);
  --clr03: #639BAD; /* Lime */

  --max-width: 1300px;

  --heading-margin: .75rem;

}

@media (width >= 1000px) {
  :root {
    --s0: calc(0.9375 * var(--font-multiplier)); /* 15pt / 16 */
  }
}

body.page-template-template-blue {
  --clr03: rgba(112,154,171,1); /* Cornflour */
}

body {
  --border-1: solid 1px var(--clr03);
  --border-2: solid 2px var(--clr03);
}

body.blog article + article {
  margin-top: calc(var(--s0) * 6);
}

@media (width <= 1000px) {
  :root {
    --font-multiplier: 2rem;
  }
}

/* Set global styles */

* {
  box-sizing: border-box;
}

/* Set up global colour scheme */

body {
	background: var(--clr01t);
	color: var(--clr00);
}

body:after,
body.home:after,
body.page--contact:after {
  content: "";
  background: url('../svg/bg-pattern.svg');
  position: absolute;
  top: 40vh;
  right: 0;
  width: 70%;
  aspect-ratio: 7 / 6;
  z-index: -2;
  opacity: .2;
}

a {
	color: var(--clr03);
}

a:hover, a:focus, a:active {
	color: var(--clr03);
}

/* Set max width in characters for readibility */

p {
  max-inline-size: var(--measure);
}

/* Exclude certain elements from max-widths */

html,
body,
div,
header,
nav,
main,
footer,
hr,
#wpadminbar * {
  max-inline-size: none;
}

/* Set margins between headings and other elements */

h1,
h2,
h3,
h4,
h5,
h6,
p,
ol,
ul {
  margin-block-start: 0; 
  margin-block-end: 0; 
  line-height: 1.2;
}

p,
ol,
ul,
label,
input,
textarea {
  font-size: var(--s0); /* Default font size */
}

small {
  font-size: var(--s-1); /* Default font size */
}

h1:has(+ p), /* style the h1 only if a p element directly follows it */
h2:has(+ p),
h3:has(+ p),
h4:has(+ p),
h5:has(+ p),
h6:has(+ p),
p:has(+ p),
ol:has(+ p),
ul:has(+ p) {
  margin-block-start: 1.125ex; 
  margin-block-end: 1.125ex; 
}

ol, ul {
  padding: 0;
}

/* Set default heading sizes based on a modular scale of 1.125 */

h1, .h1 {
	font-size: var(--s4);
}

h2, .h2 {
	font-size: var(--s3);
}

h3, .h3 {
	font-size: var(--s3);
}

h4, .h4 {
	font-size: var(--s2);
}

h5, .h5 {
	font-size: var(--s1);
}

h6, .h6 {
	font-size: var(--s0); /* Default font size */
}

.s0 {
  font-size: var(--s0);
}

.s1 {
  font-size: var(--s1);
}

/* Fonts */

@font-face {
  font-family: 'MBCorpoA';
  src: url('../fonts/mbcorpo/MBCorpoATitle-Regular-Web.ttf') format('truetype');
}

@font-face {
  font-family: 'MBCorpoS';
  src: url('../fonts/mbcorpo/MBCorpoSTitle-Regular-Web.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}


@font-face {
  font-family: 'MBCorpoS';
  src: url('../fonts/mbcorpo/MBCorpoSTitle-Light-Web.ttf') format('truetype');
  font-weight: lighter;
  font-style: normal;
}


@font-face {
  font-family: 'MBCorpoS';
  src: url('../fonts/mbcorpo/MBCorpoSTitle-Bold-Web.ttf') format('truetype');
  font-weight: bold;
  font-style: normal;
}

/* Specify fonts */

* {
	font-family: MBCorpoS, Arial, sans-serif;
}

.hdr {
  font-family: MBCorpoA, serif;
}

.underline {
  position: relative;
  padding-bottom: var(--s0);
  margin-bottom: var(--s0);
}

.underline:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 4ch;
  border-bottom: var(--border-2);
}

h1, h1 *, .h1, .h1 * {
	font-family: MBCorpoS, sans-serif;
  font-weight: bold;
  text-transform: uppercase;
}

h1.lower, 
.h1.lower, 
h2.lower, 
.h2.lower, 
h3.lower, 
.h3.lower, 
h4.lower, 
.h4.lower, 
h5.lower, 
.h5.lower, 
h6.lower, 
.h6.lower 
{
  text-transform: capitalize;
}

p + ul, p + ol {
  margin-block-start: 1em;
}

li {
  margin-inline-start: 2ch;
}

/* Image defaults */

figure img {
	max-width: 100%;
}

/* Every layout */

/* Stack */

.stack {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.stack > * {
  margin-block: 0;
} 

/*.stack > * + *:not([class^="jx_spacer"]):not(.entry-content) {
  margin-block-start: var(--s1);
}

.stack.tight > * + *:not([class^="jx_spacer"]):not(.entry-content) {
  margin-block-start: var(--s-5);
}*/


/* Box */

.box {
  --color-light: var(--clr00);
  --color-dark: var(--clr01);
  color: var(--color-dark);
  background-color: var(--color-light);
  padding: var(--s1);
  outline: 0.125rem solid transparent;
  outline-offset: -0.125rem;
}

.box * {
  color: inherit;
}

.box.invert {
  /* ↓ Dark becomes light, and light becomes dark */
  color: var(--color-light);
  background-color: var(--color-dark);
}

/* Center */

.center {
  box-sizing: content-box;
  max-inline-size: 60ch;
  margin-inline: auto;
  padding-inline-start: var(--s1);
  padding-inline-end: var(--s1);
  text-align: center;
}

/* Cluster */

.cluster {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space, 1rem);
}

/* Sidebar */

.with-sidebar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s1);
}

.sidebar {
  /* ↓ The width when the sidebar _is_ a sidebar */
  flex-basis: 20rem;
  flex-grow: 1;
}

.not-sidebar {
  /* ↓ Grow from nothing */
  flex-basis: 0;
  flex-grow: 999;
  /* ↓ Wrap when the elements are of equal width */
  min-inline-size: 50%;
}

/* 

Switcher 

Description: Used to create a list of items (elements) that will show as a stack in contexts narrower than the 
threshold, and a row in wider contexts. 

Example uses:
- 3 images or CTAs on a homepage

*/

.switcher {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  --threshold: 30rem;
}

.switcher.reverse {
  flex-direction: row-reverse;
}

.switcher > * {
  flex-grow: 1;
  flex-basis: calc((var(--threshold) - 100%) * 999);
}

.switcher > :nth-last-child(n+5),
.switcher > :nth-last-child(n+5) ~ * {
  /* In cases where there are more than 4 elements they will all be 100% wide to avoid squashing */
  flex-basis: 100%;
}

/* WordPress overrides */

.has-text-align-center {
  margin: 0 auto;
}

.has-small-font-size {
  font-size: 15px;
}

.has-medium-font-size {
  font-size: 20px;
}

.has-large-font-size {
  font-size: 20px;
}

.has-extra-large-font-size {
  font-size: 24px;
}


/* Client specific */

/**
 * Global
 */

body {
  margin: 0;
}

.site-layout {
  min-height: 100vh;
  padding: 0 var(--s2);
}

.site-layout > article > h1,
.site-layout > article > h2 {
  margin-bottom: var(--heading-margin);
}

.site-layout > article > p.has-large-font-size {
  font-size: var(--s2) !important;
}

.site-layout > article > p {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
}

.site-layout > article > p.has-text-align-center {
  max-width: 115ch;
}

.fw {
  margin-left: calc(var(--s2) * -1);
  margin-right: calc(var(--s2) * -1);
}

/**
 * Nav menu
 */

@media (width >= 1000px) {

  .menu-item {
    position: relative;
  }

  .menu-item .sub-menu {
  /*  display: none;*/
  /*  opacity: 0;*/
    padding: 1rem;
    list-style: none;
    transition: opacity 0.25s ease-in-out;
    position: absolute;
    background-color: var(--clr01b);
    width: 22ch;
    top: 2rem;
    z-index: 99;
  }

  .menu-item .sub-menu li {
    margin: 0;
  }

  .menu-item .sub-menu a {
    padding: .5rem 0;
    display: inline-block;
  }

  .menu-item:hover .sub-menu {
    display: block; /* For immediate appearance */
    opacity: 1; /* Fade in */
  }

  .menu-item:not(:hover) .sub-menu {
    display: block; /* Keep it displayed so transition can happen */
    opacity: 0; /* Fade out */
    transition-delay: 0.125s; /* Delay the fade-out */
  }

}


/**
 * Global: Buttons
 */

button.prev,
button.next,
.button,
.jx-pup-careers-form__pages #jobs-form .button {
  cursor: pointer;
  border: none;
  background-color: var(--clr03);
  background-image: none;
  box-shadow: none;
  padding: .25rem .75rem;
  border-radius: 1rem;
}

button.text,
button.text.current {
  background-color: transparent;
  padding: 0;
  border-radius: 0;
  color: #999;
  font-weight: bold;
}

button.text.current {
  color: var(--clr00);
}

button.text:hover {
  background-color: transparent;
  color: inherit;
}

button.subtle {
  cursor: pointer;
  border: none;
  background-color: var(--clr03);
  background-image: none;
  box-shadow: none;
  padding: .25rem .75rem;
  border-radius: 1rem;
  border-radius: 0;
  padding: 0;
  height: .25rem;
  width: 2rem;
}

button:hover, button:focus {
  background-color: var(--clr03);
}

button:active {
  background-color: var(--clr03);
}

.cta-button,
button.cta-button {
  border: var(--border-1);
  text-decoration: none;
  padding: .75ex 1.5ch;
  margin-top: var(--s0);
  color: var(--clr00);
  display: inline-block;
  margin-inline-end: auto;
}

.cta-button:hover, .cta-button:focus,
button.cta-button:hover, button.cta-button:focus {
  color: var(--clr03);
  background-color: var(--clr01);
  cursor: pointer;
}

.cta-button.cta-button--alt {
  color: var(--clr01);
  background-color: var(--clr00);
}

/**
 * Global: Site Header
 */

.site-header {
  background-color: var(--clr01);
  padding-left: var(--s2);
  margin-left: calc(var(--s2) * -1);
  padding-right: var(--s2);
  margin-right: calc(var(--s2) * -1);
}

.constrain {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
}

.site-logo {
  text-decoration: none;
  grid-column: 1 / -1;
  margin: var(--s6) 0;
}

.site-logo a {
  text-decoration: none;
}

.nav-container {
  grid-column: span 4;
  display: grid;
}

@media (width >= 1000px) {
  .nav-container {
    grid-column: span 8;
  }
}

.nav-container > * {
  align-self: center;
}

.nav-container a {
  font-size: var(--s0);
  font-weight: bold;
  color: var(--clr00);
}

.nav-container a:hover,
.nav-container a:focus {
  color: var(--clr03);
}

.nav-container .current-menu-item a:link, 
.nav-container .current-menu-item a:visited, 
.nav-container .current-menu-item a:hover {
  color: var(--clr00);
}

.site-tagline {
  font-size: var(--s-2);
}

.primary-menu-class {
  list-style: none;
  justify-content: center;
  max-inline-size: unset;
  padding-bottom: var(--s2);
}

@media (width >= 1000px) {
  .primary-menu-class {
    padding-bottom: 0;
    justify-content: flex-end;
  }
  .site-logo {
    grid-column: span 3;
  }
}

.primary-menu-class a {
  text-decoration: none;
}

.primary-menu-class .current-menu-item a {
  color: var(--clr03);
}

/**
 * Global: Site Footer
 */

.site-footer {
  padding-top: var(--s7);
  padding-bottom: var(--s7);
  border-top: var(--border-1);
}

.site-footer-container {
  margin-block-start: auto;
  padding-top: var(--s7);
}

.menu-footer-menu-container {
  grid-column: span 4;
  padding-top: var(--s7);
}

.footer-menu-class {
  list-style: none;
  justify-content: space-between;
  display: flex;
  flex-direction: column;
  font-size: var(--s2);
}

.footer-menu-class li {
  margin-inline-start: 0;
}

.footer-menu-class a {
  text-decoration: none;
}

.site-footer__legals {
  grid-column: span 4;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  margin-block-start: var(--s5);
}

@media (width >= 1000px) {
  .site-footer {
    margin-top: var(--s7);
    padding-top: var(--s7);
  }
  .menu-footer-menu-container {
    grid-column: span 8;
  }
  .footer-menu-class {
    list-style: none;
    justify-content: space-between;
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    column-gap: var(--s5);
    font-size: var(--s0);
  }

  .footer-menu-class li {
    grid-column: 1 / span 3;
  }

  .footer-menu-class li:nth-child(4) {
    grid-row: 1;
  }
  .footer-menu-class li:nth-child(5) {
    grid-row: 2;
  }
  .footer-menu-class li:nth-child(6) {
    grid-row: 3;
  }
  .footer-menu-class li:nth-child(7) {
    grid-row: 1;
  }
  .footer-menu-class li:nth-child(8) {
    grid-row: 2;
  }
  .footer-menu-class li:nth-child(9) {
    grid-row: 3;
  }

  .footer-menu-class li:nth-child(4), 
  .footer-menu-class li:nth-child(5), 
  .footer-menu-class li:nth-child(6) {
    grid-column: 4 / span 3;
  }

  .footer-menu-class li:nth-child(7), 
  .footer-menu-class li:nth-child(8), 
  .footer-menu-class li:nth-child(9) {
    grid-column: 7 / span 2;
  }

  .site-footer__legals {
    text-align: right;
    margin-block-start: 0;
  }
}

/**
 * Global: Entry Content
 */

.entry-content {
/*  margin-left: var(--s0);*/
/*  margin-right: var(--s0);*/
  margin-block-start: 0;
}

/**
 * Block: Heading
 */

.wp-block-heading {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
}

/**
 * Blocks: P
 */

/*.entry-content > p {
  margin-left: var(--s0);
  margin-right: var(--s0);
}
*/

/**
 * Block: Spacer
 */

.jx_spacer--1 {
  height: calc(var(--s0) * 3);
}

.jx_spacer--2 {
  height: calc(var(--s0) * 5);
}

@media (width >= 1000px) {
  .jx_spacer--1 {
    height: calc(var(--s0) * 6);
  }

  .jx_spacer--2 {
    height: calc(var(--s0) * 10);
  }
}

/**
 * Block: Image
 */

.wp-block-image {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
}

.wp-block-image.aligncenter > img {
  margin: 0 auto;
}

.wp-block-image.alignright > img {
  margin-left: auto;
}

/**
 * Block: Latest Posts
 */

.jx-latest-posts {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  max-width: var(--max-width);
}


.jx-latest-posts > .excerpt-card {
  grid-column: span 4;
}

.excerpt-text {
  margin-top: var(--s5);
  padding-bottom: var(--s2);
}

.excerpt-text h2 {
  margin-bottom: var(--s5);
}

.jx-latest-posts .featured-image {
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.jx-latest-posts a {
  text-decoration: none;
}

/**
 * Carousel
 */

.jx-carousel {
  position: relative;
  transform-style: preserve-3d;
  overflow: hidden;
  border-bottom: var(--border-2);
  box-sizing: border-box;
}

@media (width >= 1000px) {
  .jx-carousel {
    aspect-ratio: 21 / 9;
  }
}

.carousel_arrows {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  width: calc(100% - var(--s2) * 2);
  z-index: 10;
  display: flex;
  justify-content: flex-end;
  opacity: 0;
}

.carousel_arrows > button {
  background-color: rgba(255,255,255,0.3);
  background-repeat: no-repeat;
  background-size: 30%;
  background-position: center;
  aspect-ratio: 1 / 1;
  border-radius: 0;
}

.carousel_arrows > button#prevArrow {
  background-image: url('../svg/arrow-prev.svg');
  display: none;
}

.carousel_arrows > button#nextArrow {
  background-image: url('../svg/arrow.svg');
}

.jx-carousel > .slide {
  top: 0;
  left: 0;
  width: 100%;
  overflow: hidden;
  margin: auto;
  transform: translateX(-100%); /* Move 'prev' item to the left */
  transition: transform 1s;
  z-index: 1;
  box-sizing: border-box;
  position: absolute;
  height: 100%;
}

@media (width >= 1000px) {
  .jx-carousel > .slide {
    position: absolute;
    aspect-ratio: 21 / 9;
  }
  .carousel_arrows {
    opacity: 1;
  }
}

.jx-carousel > .slide.active {
  opacity: 1;
  transform: translateX(0);
  z-index: 10;
  position: relative;
/*  display: none;*/
}

.jx-carousel > .slide.active + .slide.active,
.jx-carousel > .slide.active * .slide.active {
  position: absolute;
  opacity: 0;
}

.slide.prev {
  transform: translateX(-100%); /* Move 'prev' item to the left */
  transition: transform 1s;
}
.slide.next {
  transform: translateX(100%); /* Move 'next' item to the right */
  transition: transform 0s;
}

.jx-carousel figure.slide__content {
  position: absolute;
  height: 100%;
  width: 100%;
}

.jx-carousel figure.slide__content > img {
/*  position: absolute;*/
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (width >= 1000px) {
  .jx-carousel > .slide.active {
    position: absolute;
  }
  .jx-carousel figure.slide__content {
    position: absolute;
    height: 100%;
    width: 100%;
  }

  .jx-carousel figure.slide__content > img {
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}

.master-grid {
  position: relative;
  height: 100%;
  width: 100%;
  max-width: var(--max-width);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  column-gap: var(--s5);
  box-sizing: border-box;
}

.master-grid.half {
  grid-template-columns: repeat(2, 1fr);
}

@media (width >= 1000px) {
  .master-grid {
    grid-template-columns: repeat(12, 1fr);
  }
  .master-grid.half {
    grid-template-columns: repeat(6, 1fr);
  }
}

.overlay {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}

.slide__overlay {
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 10;
  padding: var(--s5);
  grid-column: 1 / span 4;
  margin-top: auto;
  border-top: var(--border-2);
  color: var(--clr00);
}

@media (width <= 1000px) {
  .overlay.master-grid {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    position: relative;
  }
  .slide__overlay {
    margin-top: unset;
  }
}

.slide_navigation {
  position: absolute;
  z-index: 12;
  bottom: var(--s0);
  left: 50%;
  transform: translateX(-50%);
}

.slide_navigation > ul {
  display: flex;
  list-style: none;
  padding-top: .5rem;
}

.slide_navigation > ul > li {
  margin-inline-end: .5rem;
}

.slide_navigation > ul > li > button {
  cursor: pointer;
  background-color: var(--clr00);
}

.slide_navigation > ul > li > button.current {
  background-color: var(--clr03);
}

/**
 * Cards
 */

.jx-cards {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  max-width: var(--max-width);
}

.jx-cards > a.card {
  position: relative;
  aspect-ratio: 63 / 40;
  position: relative;
  grid-column: span 4;
  text-decoration: none;
  padding: var(--s5);
  color: var(--clr00);
}

.jx-cards > a.card:before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgb(255,255,255);
  background: linear-gradient(0deg, rgba(255,255,255,0) 0%, rgba(0,0,0,0.5) 100%);
  z-index: 1;
}

body.blog .jx-cards > a.card:before {
  height: 100%;
}

.jx-cards > a.card:after {
  position: absolute;
  content: "";
  background-image: url('../svg/arrow.svg');
  background-repeat: no-repeat;
  background-size: 30%;
  background-position: center;
  aspect-ratio: 1 / 1;
  height: 2.5rem;
  z-index: 2;
  top: var(--s5);
  right: var(--s5);
}

.jx-cards > a.card > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.jx-cards > a.card > .card-text > p {
  z-index: 10;
  position: relative;
  color: inherit;
}

.jx-cards.style--one > a.card > .card-text {
  color: var(--clr00);
}

body.blog .jx-cards > a.card > .card-text h2.headline {
  z-index: 10;
  position: relative;
}

.jx-cards.style--two > a.card {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.jx-cards.style--two > a.card:after {
  content: unset;
}

.jx-cards.style--two > a.card > .card-text {
  color: var(--clr01);
  background-color: rgba(217,217,217,0.9);
  display: block;
  position: relative;
  z-index: 15;
  padding: var(--s5);  
}

@media (width <= 1000px) {
  .jx-cards.master-grid {
    display: flex;
    flex-direction: column;
  }
}
@media (width >= 1000px) {
  .jx-cards > a.card {
    grid-column: span 6;
  }
  .jx-cards > a.card:before {
    height: 50%;
  }
  .jx-cards.style--two > a.card > .card-text {
    width: 45%;
    margin-block-end: calc(var(--s5) * -2);
  }
}

/**
 * Signpost
 */

.jx-signpost {
  position: relative;
  color: var(--clr00);
}

.jx-linkbar,
.jx-signpost__linkbar {
  grid-row: 1 / span 1; 
  grid-column: 1 / -1; 
  background-color: var(--clr03);
  color: inherit;
  padding: var(--s2);
  padding-right: 8rem;
  font-size: var(--s3);
  display: flex;
  z-index: 2;
  text-transform: uppercase;
}

.jx-signpost__linktitle {
  margin-inline-end: 1ch;
  color: inherit;
}

.jx-signpost__link {
  color: var(--clr00);
  position: relative;
  text-decoration: none;
  width: 100%;
  color: inherit;
}

a.jx-signpost__link {
  color: inherit;
}

.jx-signpost__link:after {
  position: absolute;
  content: "";
  top: 0;
  right: -5rem;
  bottom: 0;
  background-color: rgba(255,255,255,0.3);
  background-image: url('../svg/arrow.svg');
  background-repeat: no-repeat;
  background-size: 30%;
  background-position: center;
  aspect-ratio: 1 / 1;
  width: 5rem;
  height: 5rem;
}

.jx-signpost__textcontent {
  grid-row: 2 / span 2; 
  grid-column: 1 / -1; 
  background-color: var(--clr01b);
}

.jx-signpost__textcontent__inner {
  grid-column: 1 / span 4;
  padding-block-start: 3rem;
  padding-block-end: 3rem;
  padding-left: var(--s2);
  padding-right: var(--s2);
}

.jx-signpost__imagewrap {
  grid-column: 1 / -1; 
}

@media (width >= 1000px) {
  .jx-linkbar {
    grid-column: 1 / span 12; 
    font-size: var(--s4);
  }

  .jx-linkbar.third {
    width: 31.7%;
  }

  .jx-signpost__linkbar {
    grid-column: 5 / span 8; 
    font-size: var(--s3);
  }

  .jx-linkbar,
  .jx-signpost__linkbar {
    padding-right: 6rem;
  }

  .jx-signpost__link:after {
    width: 2.5rem;
    height: 2.5rem;
    right: -4.5rem;
  }

  .jx-signpost__textcontent {
    grid-column: 1 / span 6; 
    grid-row: 1 / span 2; 
  }

  .jx-signpost__textcontent__inner {
    grid-column: 2 / span 3;
    padding-left: unset;
    padding-right: unset;
    padding-block-start: 6rem;
  padding-block-end: 6rem;
  }

  .jx-signpost__imagewrap {
    grid-column: 5 / span 8; 
    grid-row: 1 / span 3; 
  }
}


/**
 * Billboard
 */

.jx-billboard {
  position: relative;
}

.jx-billboard.c {
  max-width: var(--max-width);
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
}

.jx-billboard:not(.overlay-overlay_simple) {
  border-bottom: var(--border-2);
}

.jx-billboard img {
  width: 100%;
  object-fit: cover;
}

.jx-billboard  > .overlay {
  position: relative;
}

.billboard__overlay.single,
.billboard__overlay.single_dark {
  background-color: rgba(255, 255, 255, 1);
  z-index: 10;
  padding: var(--s7);
  height: 100%;
  grid-column: 1 / span 4;
  margin-block-start: auto;
  color: var(--clr01);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.billboard__overlay.single_dark {
  background-color: rgba(0, 0, 0, .7);
  color: var(--clr00);
}

.billboard__overlay.single:after {
  position: absolute;
  content: "";
  background: url('../svg/bg-pattern-2.svg');
  top: 0;
  left: -7vw;
  height: 95%;
  aspect-ratio: 1 / 1;
  z-index: -1;
}

.billboard__overlay.billboard__overlay--tabbed {
  background-color: rgba(0, 0, 0, 0.55);
  z-index: 10;
  padding: var(--s7);
  height: auto;
  grid-column: 1 / span 5;
  margin-block-start: auto;
  color: var(--clr00);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.billboard__overlay.billboard__overlay--tabbed:after {
  display: none;
}

.tab-section:not(.current) {
  display: none;
}

.tab-headings {
  display: flex;
  gap: 3ch;
  position: relative;
  padding-bottom: var(--s0);
  margin-bottom: var(--s0);
}

.tab-headings .current {
  position: relative;
}
.tab-headings .current:after {
  content: "";
  position: absolute;
  bottom: calc(var(--s0) * -1);
  left: 0;
  width: 2ch;
  border-bottom: var(--border-2);
}

.video-iframe-container {
  display: none;
  position: absolute;
  width: 100%;
  top: 0;
  left: 0;
  right: 0;
  padding-bottom: 56.25%; /* 16:9 aspect ratio */
  height: 0;
  overflow: hidden;
  max-width: 100%;
  background: #000;
  z-index: 95;
}

.video-iframe-container.portrait {
    padding-bottom: 177.78%; /* 9:16 aspect ratio */
}

.video-iframe-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.billboard__content {
  margin-top: 0;
}

.billboard__play {
  width: 15%;
  aspect-ratio: 1 / 1;
  background-image: url('../svg/play-button.svg');
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: center;
  border-radius: 99rem;
  background-color: transparent;
  opacity: .4;
  filter: invert(1);
/*  border-radius: 0;*/
/*  background-color: var(--clr00);*/
/*  color: var(--clr01);*/
/*  padding: .75ex 1.5ch;*/
  position: absolute;
  left: 50%;
  top: 32%;
  transform: translateX(-50%) translateY(-50%);
  z-index: 80;
/*  font-size: var(--s3);*/
/*  border: var(--border-1);*/
}

button.billboard__play:hover, button.billboard__play:focus {
  background-color: var(--clr03);
}

.billboard-close-button {
  position: absolute;
  top: var(--s1);
  right: var(--s1);
  width: 3.5rem;
  border: none;
  cursor: pointer;
  z-index: 99;
  aspect-ratio: 1 / 1;
  background-image: url('../svg/close-button.svg');
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: center;
  border-radius: 99rem;
  background-color: transparent;
  position: absolute;
  background-color: var(--clr01);
}

@media (width >= 1000px) {
  .jx-billboard.type-image,
  .jx-billboard.type-video {
    aspect-ratio: 21 / 9;
  }
  .jx-billboard.c  > .overlay {
/*    min-height: 45vh;*/
  }

  .jx-billboard.fw  > .overlay {
/*    position: absolute;*/
    min-height: 45vh;
  }
  .billboard__overlay {
    background-color: rgba(255, 255, 255, 0.55);
  }
  .billboard__content {
    position: absolute;
    height: 100%;
    width: 100%;
  }
  .billboard__content img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .billboard__play {
    filter: none;
/*    width: 10vw;*/
    top: 50%;
    font-size: var(--s2);
  }
  .video-iframe-container {
    padding-bottom: 43.25%; /* 21:9 aspect ratio */
  }
}

/**
 * Image + Text panel
 */

.jx-image-text-panel--wrapper {
  padding-top: calc(var(--s0) * 3);
  padding-bottom: calc(var(--s0) * 3);
  padding-left: var(--s2);
  padding-right: var(--s2);
}

.jx-image-text-panel {
  position: relative;
}

.jx-image-text-panel:not(.transparent):after {
  background-color: var(--clr01t);
  position: absolute;
  content: "";
  top: calc(var(--s0) * -7);
  bottom: calc(var(--s0) * -7);
  left: 50%;
  width: 98vw; /* to account for scroll bar */
  transform: translateX(-50%);
  z-index: -1;
}

.jx-image-text-panel h2 {
  text-transform: uppercase;
}

.jx-image-text-panel figure {
  grid-column: 1 / span 4;
  grid-row-start: 1;
}

.jx-image-text-panel .text-content {
  grid-column: 1 / span 4;
  display: grid;
  place-content: center;
  background-color: rgba(0,0,0,0.5);
  grid-row-start: 1;
  padding: var(--s2);
  z-index: 10;
}

.jx-image-text-panel.reverse figure {
  grid-column: 1 / span 4;
}

.jx-image-text-panel.reverse .text-content {
  grid-column: 1 / span 4;
}

@media (width <= 1000px) {
  .jx-image-text-panel.master-grid {
    display: flex;
    flex-direction: column;
  }
}

@media (width >= 1000px) {
  .jx-image-text-panel figure {
    grid-column: 1 / span 7;
    padding-right: var(--s7);
  }

  .jx-image-text-panel .text-content {
    grid-column: 8 / span 5;
    padding: var(--s2);
    padding-inline-end: 6ch;
    background-color: transparent;
  }
  
  .jx-image-text-panel.reverse figure {
    grid-column: 6 / span 7;
  }

  .jx-image-text-panel.reverse .text-content {
    grid-column: 1 / span 5;
  }

  .jx-image-text-panel--wrapper {
    padding-left: 0;
    padding-right: 0;
    padding-top: calc(var(--s0) * 6);
    padding-bottom: calc(var(--s0) * 6);
  }
  .jx-image-text-panel--wrapper .jx-image-text-panel .text-content {
    place-content: end;
  }
}

/**
 * JX Feature
 */

.jx-feature__images {
  grid-column: 1 / span 4;
  grid-row-start: 1;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  position: relative;
}

.jx-feature__text {
  grid-column: 1 / span 4;
  grid-row-start: 2;
}

.jx-feature__images > .slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  margin: auto;
  transition: transform .5s, opacity .5s, z-index .5s;
  z-index: 1;
  box-sizing: border-box;
  opacity: 0;
}

.jx-feature__images > .slide.active {
  opacity: 1;
  transform: translateX(0);
  z-index: 10;
  position: relative;
}

.jx-feature__images > .slide.active + .slide.active,
.jx-feature__images > .slide.active * .slide.active {
  position: absolute;
  opacity: 0;
}

.jx-feature__images figure.slide__content {
  position: absolute;
  height: 100%;
  width: 100%;
}

.jx-feature__images figure.slide__content > img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.jx-feature .slide_navigation {
  position: relative;
  grid-column: 1 / span 4;
  grid-row-start: 2; 
  transform: none;
  left: 0;
  margin-block-start: 1rem;
}

.jx-feature .slide_navigation ul {
  justify-content: center;
}

.jx-feature .slide_navigation > ul > li > button:not(.current) {
  background-color: #666;
}

.jx-feature .slide_navigation > ul > li {
  margin-inline-end: 0;
}

@media (width >= 1000px) {
  .jx-feature__images {
    grid-column: 1 / span 7;
    grid-row-start: 1;
  }

  .jx-feature__text {
    grid-column: 9 / span 3;
    grid-row-start: 1;
  }
  .jx-feature .slide_navigation {
    grid-column: 1 / span 7;
  }
}

/**
 * Text Block
 */

.jx-text-block {
  padding-top: calc(var(--s0) * 6);
  padding-bottom: calc(var(--s0) * 6);
  padding-left: var(--s2);
  padding-right: var(--s2);
}

.jx-text-block h2 {
  text-transform: uppercase;
  margin-block-end: var(--heading-margin);
}

.jx-text-block.jx-text-block--light {
  background-color: var(--clr02);
  background-image: url('../svg/bg-pattern-2.svg');
  background-position: center right;
  background-repeat: no-repeat;
  background-size: 75%;
  color: var(--clr01b);
  border-bottom: var(--border-2);
}

@media (width >= 1000px) {
  .jx-text-block {
    padding-left: 0;
    padding-right: 0;
  }
}

/**
 * Vacancies
 */

#recent-jobs p:nth-last-child {
  grid-column: 1 / -1;
  text-align: center;
  max-width: unset;
}

#jobs-form .more-link {
  display: inline-block;
}

.jx-vacancies .jx-vacancies__cards,
#recent-jobs,
#recent-jobs-content {
  padding-top: calc(var(--s0) * 6);
  gap: var(--s5);
  position: relative;
  height: 100%;
  width: 100%;
  max-width: var(--max-width);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  column-gap: var(--s5);
  box-sizing: border-box;
}

@media (width >= 1000px) {
  .jx-vacancies .jx-vacancies__cards,
  #recent-jobs,
  #recent-jobs-content {
    grid-template-columns: repeat(12, 1fr);
  }
}

#search-results .card,
.jx-pup-careers-form__pages .card,
.jx-vacancies .card,
#recent-jobs .card,
#recent-jobs-content .card {
  grid-column: span 4;
  background-color: var(--clr02);
  background-image: url('../svg/bg-pattern-2.svg');
  background-position: center right;
  background-repeat: no-repeat;
  background-size: cover;
  color: var(--clr01b);
  text-align: left;
}

.jx-pup-careers-form__pages .card,
#recent-jobs .card,
#recent-jobs-content .card {
  grid-column: span 4;
  background-color: var(--clr02);
  background-image: url('../svg/bg-pattern-2.svg');
  background-position: center right;
  background-repeat: no-repeat;
  background-size: cover;
  color: var(--clr01b);
  text-align: left;
}

.jx-pup-careers-form__pages .card {
  background-image: url('https://www.mercedes-amg-hpp.com/wp-content/themes/cxpress-mercedes/assets/svg/bg-pattern-2.svg');
}

.jx-pup-careers-form__pages .card figure,
.jx-vacancies .card figure,
#recent-jobs-content .card figure {
  aspect-ratio: 3 / 2;
  overflow: hidden;
  border-bottom: var(--border-2);
}

.jx-pup-careers-form__pages .card figure img,
.jx-vacancies .card figure img,
#recent-jobs-content .card figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.jx-pup-careers-form__pages .card .card-content,
#recent-jobs .card .card-content,
#recent-jobs-content .card .card-content {
  padding: var(--s5);
  height: 100%;
  display: flex;
  flex-direction: column;
}

.jx-vacancies .card {
  display: flex;
  flex-direction: column;
}

.jx-vacancies .card .card-content {
  padding: var(--s5);
  height: auto;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.apply-button {
  margin-block-start: auto;
}

.jx-pup-careers-form__pages .card .card-content a.job-link,
.jx-vacancies .card .card-content a.job-link,
#recent-jobs-content .card .card-content .job-link {
  text-decoration: none;
  color: var(--clr01);
  font-size: var(--s0);
}

.search-button,
.jx-pup-careers-form__pages .apply-button > .job-link:link,
#recent-jobs-content .apply-button > .job-link:link {
  border: 1px solid var(--clr01b);
  background-color: rgba(255,255,255,0.3);
  text-decoration: none;
  padding: .75ex 1.5ch;
  color: var(--clr01b);
  display: inline-block;
  margin-inline-end: auto;
  margin-block-start: var(--s2);
}

.card-content p.excerpt {
  margin-bottom: 1rem;
}

.card-content .search-button {
  margin-top: auto;
}

.search-button:hover, .search-button:focus,
.jx-pup-careers-form__pages .apply-button > .job-link:hover, 
.jx-pup-careers-form__pages .apply-button > .job-link:focus,
.jx-pup-careers-form__pages .card .card-content .apply-button a.job-link:hover, 
.jx-pup-careers-form__pages .card .card-content .apply-button a.job-link:focus,
#recent-jobs-content .card .card-content .job-link:hover, 
#recent-jobs-content .card .card-content .job-link:focus,
#recent-jobs-content .apply-button > .job-link:hover, 
#recent-jobs-content .apply-button > .job-link:focus {
  color: var(--clr00);
  background-color: var(--clr01b);
}

@media (width >= 1000px) {
  #search-results .card,
  .jx-pup-careers-form__pages .card,
  #recent-jobs .card,
  .jx-vacancies .card,
  #recent-jobs-content .card {
    grid-column: span 3;
  }
}

body.page-template-pageup-careers .card-content p {
  font-weight: bold;
  margin-block-start: 1.125ex; 
  margin-block-end: 1.125ex; 
}

body.page-template-pageup-careers .card-content p span {
  font-weight: normal;
}

/**
 * Contact form
 */

.error {
    border: 2px solid red;
}

#form_feedback.message {
  background-color: rgba(255,255,255,0.2);
  padding: .5rem;
  margin-top: 1rem;
}

input:focus, textarea:focus {
  background-color: #dde;
}

.jx-contact-form {
  background-color: var(--clr01b);
  grid-column: 1 / -1;
  padding: var(--s2);
}

.jx-contact-form .h1 {
  text-transform: unset;
}

.jx-contact-form fieldset {
  grid-column: 1 / -1;
  border: none;
  padding: 0;
  display: flex;
  flex-flow: row wrap;
  gap: var(--s5);
}

.jx-contact-form fieldset > input {
  flex: 1 0 90%;
  padding: 1ch;
}

.jx-contact-form fieldset > textarea {
  flex: 0 0 100%;
  padding: 1ch;
}

.jx-contact-form fieldset + div {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.jx-contact-form input[type="submit"] {
  margin-top: var(--s2);
  margin-right: auto;
  background-color: var(--clr03);
  border: none;
  padding: 1ch 2ch;
  cursor: pointer;
  text-transform: uppercase;
}

/* Style the placeholder text */
.jx-contact-form input::placeholder,
.jx-contact-form textarea::placeholder {
    text-transform: uppercase;
}

/* Style the placeholder text for different browsers */
.jx-contact-form input::-webkit-input-placeholder,
.jx-contact-form textarea::-webkit-input-placeholder {
    text-transform: uppercase;
}

.jx-contact-form input::-moz-placeholder,
.jx-contact-form textarea::-moz-placeholder {
    text-transform: uppercase;
}

.jx-contact-form input:-ms-input-placeholder,
.jx-contact-form textarea:-ms-input-placeholder {
    text-transform: uppercase;
}

.jx-contact-form input:-moz-placeholder,
.jx-contact-form textarea:-moz-placeholder {
    text-transform: uppercase;
}


.jx-honeypot {
    display: none !important;
    visibility: hidden !important;
    position: absolute !important;
    left: -9999px !important;
}


@media (width >= 1000px) {
  .jx-contact-form {
    padding-left: 0;
    padding-right: 0;
    padding-block-start: calc(var(--s0) * 5);
    padding-block-end: calc(var(--s0) * 5);
  }
  .jx-contact-form fieldset {
    grid-column: 2 / span 6;
  }

  .jx-contact-form fieldset > input {
    flex: 1 0 40%;
  }

  .jx-contact-form fieldset + div {
    grid-column: 9 / span 3;
  }
}

/**
 * Columns
 */

.jx-columns .column {
  grid-column: 1 / -1;
}

.jx-columns .column a {
  text-decoration: none;
  background-color: var(--clr00);
  color: var(--clr01);
  padding: .75ex 1.5ch;
  margin-top: auto;
  margin-bottom: 2em;
  border: var(--border-1);
}

.jx-columns ul {
  list-style-image: url('../svg/bullet.svg');
}

.jx-columns ul li {
  padding-inline-start: 1ch;
  margin-block-end: var(--heading-margin);
}

.jx-columns .h1 {
  text-transform: none;
  margin-block-end: var(--heading-margin);
}

/* Solid style */

.jx-columns.style--solid .column {
  background-color: var(--clr01b);
  padding: var(--s2);
}

.jx-columns.style--solid .column + .column {
  margin-block-start: var(--s2);
}

.jx-columns.style--solid .column figure {
  margin-top: calc(var(--s2) * -1);
  margin-left: calc(var(--s2) * -1);
  margin-right: calc(var(--s2) * -1);
  margin-bottom: var(--s2);
}

.jx-columns.style--solid .column .h1 {
  text-transform: uppercase;
  margin-block-end: calc(var(--heading-margin) * 2);
}

.expandable-section input[type="radio"] {
  display: none;
}

.expandable-section label {
  font-weight: bold;
  position: relative;
  display: inline-block;
  cursor: pointer;
}

.expandable-section label:after {
  position: absolute;
  content: "";
  top: 50%;
  right: 0;
  bottom: 0;
  background-image: url('../svg/arrow.svg');
  background-repeat: no-repeat;
  background-size: 30%;
  background-position: center;
  aspect-ratio: 1 / 1;
  width: 1.5rem;
  height: 1.5rem;
  transform: translateY(-50%) translateX(1.5rem);
}

.expandable-section input[type="radio"]:checked + label {
}

.expandable-section input[type="radio"]:checked + label:after {
  transform: translateX(1.75rem) translateY(-50%) rotate(90deg);
}

.expandable-section {
  margin-bottom: 1rem;
}

.jx-columns iframe {
  width: 100%;
  aspect-ratio: 16 / 9;
}

@media (width >= 1000px) {
  .jx-columns {
    display: flex;
    gap: var(--s5);
  }

  .jx-columns .column {
    flex: 1 0 23%;
  }

  .jx-columns.style--solid .column + .column {
    margin-block-start: 0;
  }
}

/**
 * Tabbed Content
 */

.jx-tabbed-content {

}

/* Styling for the tabs (optional) */
.jx-tabbed-content label {
    cursor: pointer;
    display: inline-block;
    font-size: var(--s2);
    margin-right: 3rem;
    font-weight: bold;
    color: rgb(118,118,118);
    padding-bottom: var(--s0);
    margin-bottom: var(--s0);
}

.jx-tabbed-content label:hover {
    color: var(--clr00);
}

.jx-tabbed-content input[type="radio"]:checked + label {
  color: var(--clr00);
  position: relative;
}

.jx-tabbed-content input[type="radio"]:checked + label:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 4ch;
  border-bottom: var(--border-2);
}

.jx-tabbed-content input[type="radio"] {
    display: none;
}

.tab {
  display: none;
}

/* Show the corresponding tab content when the associated radio button is checked */
.content .content-item {
    display: none;
}

.content .active {
    display: block;
}


.jx-tabbed-content .content {
  margin-top: var(--s2);
}

.jx-tabbed-content .tab figure {
  grid-column: 1 / -1;
  margin-bottom: var(--s2);
}

.jx-tabbed-content .tab .text-content {
  grid-column: 1 / -1;
}

@media (width >= 1000px) {
  .jx-tabbed-content .tab figure {
    grid-column: 1 / span 7;
  }

  .jx-tabbed-content .tab .text-content {
    grid-column: 9 / span 4;
  }
}

/*/* FAQs */

.jx-faqs {
  background-color: rgb(33, 33, 33);
  padding-top: calc(var(--s0) * 3);
  padding-bottom: calc(var(--s0) * 3);
}

.jx-faqs .constrain {
  padding-left: var(--s2);
  padding-right: var(--s2);
}

.jx-faqs h2 {
  padding: var(--s2) 0;
  border-bottom: 1px solid rgb(118, 118, 118);
}

.faq-section {
  padding: var(--s2) 0;
  border-bottom: 1px solid rgb(118, 118, 118);
}

/* Styling for the tabs (optional) */
.jx-faqs label {
  cursor: pointer;
  display: block;
  font-size: var(--s2);
  font-weight: bold;
  color: var(--clr00);
  padding-top: var(--s0);
  padding-bottom: var(--s0);
  position: relative;
}

.jx-faqs label:after {
  position: absolute;
  content: "";
  top: 50%;
  right: 0;
  bottom: 0;
  background-color: rgba(255, 255, 255, 0.3);
  background-image: url('../svg/arrow.svg');
  background-repeat: no-repeat;
  background-size: 30%;
  background-position: center;
  aspect-ratio: 1 / 1;
  width: 2rem;
  height: 2rem;
  transform: translateY(-50%);
}

.jx-faqs label:hover {
  color: var(--clr00);
}

.jx-faqs input[type="checkbox"]:checked + label {
  color: var(--clr00);
  position: relative;
}

.jx-faqs input[type="checkbox"]:checked + label:after {
  transform: translateY(-50%) rotate(90deg);
}

.jx-faqs input[type="checkbox"] {
  display: none;
}

.jx-faqs input[type="checkbox"] + label + .answer {
  display: none;
}

.jx-faqs input[type="checkbox"]:checked + label + .answer {
  display: block;
}


.answer {
  display: none;
}

/* Show the corresponding tab content when the associated radio button is checked */
.question:checked + label + .answer {
    display: block;
}
/*
.jx-tabbed-content .content {
  margin-top: var(--s2);
}

.jx-tabbed-content .tab figure {
  grid-column: 1 / -1;
  margin-bottom: var(--s2);
}

.jx-tabbed-content .tab .text-content {
  grid-column: 1 / -1;
}

@media (width >= 1000px) {
  .jx-tabbed-content .tab figure {
    grid-column: 1 / span 7;
  }

  .jx-tabbed-content .tab .text-content {
    grid-column: 9 / span 4;
  }
}*/

/**
 * Career Search Form
 */

form.career-search {
  text-align: center;
  padding-top: calc(var(--s0) * 6);
  padding-bottom: calc(var(--s0) * 6);
}

form.career-search input {
  margin-inline-start: 1ch;
  padding: 0 .5ch;
  padding-inline-end: 2.5rem;
}

form.career-search label {
  position: relative;
}

.search-submit {
  position: relative;
  top: 50%;
  right: 0;
  background-color: transparent;
  border-radius: 0;
  padding: 0;
  height: 4rem;
  aspect-ratio: 1 / 1;
}

.search-submit:hover, .search-submit:focus {
  background-color: transparent;
}

@media (width >= 1000px) {
  .search-submit {
    transform: translateX(-40px) translateY(8px);
    height: 2rem;
  }
}

/**
 * Timeline
 */

.jx-timeline {
  position: relative;
  padding-left: 3rem;
}

.jx-timeline:before {
  position: absolute;
  content: "";
  border-left: 1px solid var(--clr03);
  top: 2rem;
  bottom: 2rem;
  left: 1rem;
  width: 2px;
}

.jx-timeline .event .name {
  position: relative;
}

.jx-timeline .event .name:before {
  position: absolute;
  content: "";
  background-color: var(--clr03);
  top: 50%;
  transform: translateX(-3px) translateY(-50%);
  height: 7px;
  left: -2rem;
  width: 7px;
}

@media (width >= 1000px) {
  .jx-timeline {
    padding-left: 0;
    display: flex;
    gap: var(--s5);
  }

  .event {
    flex: 1 0 10%;
    box-sizing: border-box;
    text-align: center;
  }

  .jx-timeline .event .name {
    margin-bottom: 3rem;
  }

  .jx-timeline .event .name:before {
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(1rem);
  }

  .jx-timeline:before {
    border-left: none;
    border-top: 1px solid var(--clr03);
    bottom: unset;
    top: 4.05rem;
    right: 9%;
    left: 9%;
    height: 2px;
    width: auto;
  }
}

/**
 * PageUp People Careers Form
 */


.jx-pup-careers-form__pages p {
  max-width: unset;
  grid-column: 1 / -1;
}

.jx-pup-careers-form__pages .more-link.button {
  border: 1px solid var(--clr01b);
  background-color: var(--clr00);
  background-image: none;
  text-decoration: none;
  text-transform: uppercase;
  padding: .75ex 1.5ch;
  color: var(--clr01b);
  margin-inline-end: auto;
  margin-bottom: 2rem;
  margin-block-start: var(--s2);
  font-weight: normal;
  border-radius: 0;
}

.jx-pup-careers-form {
  text-align: center;
}

.jx-pup-careers-filters {
  display: block;
  margin-bottom: var(--s5);
}

jx-pup-careers-filters > #search-filters {
  display: inline-block !important;
}

@media (width >= 1000px) {

  .jx-pup-careers-filters > #search-filters {
    display: inline-block;
    text-align: center;
    width: 60%;
    background-color: var(--clr03);
    padding: 1rem 1rem 0 1rem;
  }

  .jx-pup-careers-filters > #search-filters h3 {
    margin-right: 1ch;
    font-size: var(--s0);
    float: left;
    margin-top: .25ch;
  }

  .jx-pup-careers-filters > #search-filters select {
    margin-bottom: 1rem;
  }

  .jx-pup-careers-filters > #search-filters *:nth-child(5) {
    clear: left;
  }


  .jx-pup-careers-filters > #search-filters .filter-wrapper {
    margin-right: 2ch;
    float: left;
  }
}

.jx-pup-careers-form__search {
  text-align: center;
}

.jx-pup-careers-form__search {
  position: relative;
  margin-top: calc(var(--s0) * 6);
}

.jx-pup-careers-form__search {
  text-align: center;
}

.jx-pup-careers-form__search > label {
  text-transform: uppercase;
  font-weight: bold;
  font-size: var(--s4);
}

.jx-pup-careers-form__search input {
  margin-inline-start: 1ch;
  font-size: var(--s4);
}

.jx-pup-careers-form__messages {
  text-align: center;
  padding-top: calc(var(--s0) * 6);
}

/**
 * PageUp People Job Page
 */

#job-content {
  text-align: left;
}
#job-content h2 {
  text-align: center;
}
#job-content p {
  max-width: unset;
}
#job-content .button {
  color: var(--clr01);
  text-decoration: none;
}

#job-details,
#job-details + p {
  margin-bottom: 2rem;
}

/**
 * PageUp People search results
 */

#search-results {
  position: relative;
  height: 100%;
  width: 100%;
  max-width: var(--max-width);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s5);
  box-sizing: border-box;
}

@media (width >= 1000px) {
  #search-results {
    grid-template-columns: repeat(12, 1fr);
  }
}

/**
 * Back to top arrow
 */

#back-to-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 40px;
    height: 40px;
    background-color: #000;
    color: #fff;
    text-align: center;
    line-height: 40px;
    font-size: 24px;
    border-radius: 50%;
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s, visibility 0.3s;
    z-index: 99;
}

#back-to-top img {
  width: 60%;
  height: 60%;
  position: absolute;
  left: 50%;
  top: 0%;
  transform: rotate(-90deg) translateX(-35%) translateY(-50%);
}

#back-to-top.show {
    opacity: 1;
    visibility: visible;
}