/*! sanitize.css v7.0.3 | CC0 License | github.com/csstools/sanitize.css */

/* Document
 * ========================================================================== */

/**
 * 1. Remove repeating backgrounds in all browsers (opinionated).
 * 2. Add border box sizing in all browsers (opinionated).
 */

*,
::before,
::after {
  background-repeat: no-repeat; /* 1 */
  box-sizing: border-box; /* 2 */
}

/**
 * 1. Add text decoration inheritance in all browsers (opinionated).
 * 2. Add vertical alignment inheritance in all browsers (opinionated).
 */

::before,
::after {
  text-decoration: inherit; /* 1 */
  vertical-align: inherit; /* 2 */
}

/**
 * 1. Use the default cursor in all browsers (opinionated).
 * 2. Use the default user interface font in all browsers (opinionated).
 * 3. Correct the line height in all browsers.
 * 4. Use a 4-space tab width in all browsers (opinionated).
 * 5. Prevent adjustments of font size after orientation changes in
 *    IE on Windows Phone and in iOS.
 * 6. Breaks words to prevent overflow in all browsers (opinionated).
 */

html {
  cursor: default; /* 1 */
  font-family:
    system-ui,
    /* macOS 10.11-10.12 */ -apple-system,
    /* Windows 6+ */ Segoe UI,
    /* Android 4+ */ Roboto,
    /* Ubuntu 10.10+ */ Ubuntu,
    /* Gnome 3+ */ Cantarell,
    /* KDE Plasma 5+ */ Noto Sans,
    /* fallback */ sans-serif,
    /* macOS emoji */ "Apple Color Emoji",
    /* Windows emoji */ "Segoe UI Emoji",
    /* Windows emoji */ "Segoe UI Symbol",
    /* Linux emoji */ "Noto Color Emoji"; /* 2 */

  line-height: 1.15; /* 3 */
  -moz-tab-size: 4; /* 4 */
  -o-tab-size: 4;
     tab-size: 4; /* 4 */
  -ms-text-size-adjust: 100%; /* 5 */
  -webkit-text-size-adjust: 100%; /* 5 */
  word-break: break-word; /* 6 */
}

/* Sections
 * ========================================================================== */

/**
 * Remove the margin in all browsers (opinionated).
 */

body {
  margin: 0;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
 * ========================================================================== */

/**
 * 1. Add the correct sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * Add the correct display in IE.
 */

main {
  display: block;
}

/**
 * Remove the list style on navigation lists in all browsers (opinionated).
 */

nav ol,
nav ul {
  list-style: none;
}

/**
 * 1. Use the default monospace user interface font
 *    in all browsers (opinionated).
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
  font-family:
    /* macOS 10.10+ */ Menlo,
    /* Windows 6+ */ Consolas,
    /* Android 4+ */ Roboto Mono,
    /* Ubuntu 10.10+ */ Ubuntu Monospace,
    /* KDE Plasma 5+ */ Noto Mono,
    /* KDE Plasma 4+ */ Oxygen Mono,
    /* Linux/OpenOffice fallback */ Liberation Mono,
    /* fallback */ monospace; /* 1 */

  font-size: 1em; /* 2 */
}

/* Text-level semantics
 * ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */

a {
  background-color: transparent;
}

/**
 * Add the correct text decoration in Edge, IE, Opera, and Safari.
 */

abbr[title] {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
  font-weight: bolder;
}

/**
 * 1. Use the default monospace user interface font
 *    in all browsers (opinionated).
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
  font-family:
    /* macOS 10.10+ */ Menlo,
    /* Windows 6+ */ Consolas,
    /* Android 4+ */ Roboto Mono,
    /* Ubuntu 10.10+ */ Ubuntu Monospace,
    /* KDE Plasma 5+ */ Noto Mono,
    /* KDE Plasma 4+ */ Oxygen Mono,
    /* Linux/OpenOffice fallback */ Liberation Mono,
    /* fallback */ monospace; /* 1 */

  font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */

small {
  font-size: 80%;
}

/*
 * Remove the text shadow on text selections in Firefox 61- (opinionated).
 * 1. Restore the coloring undone by defining the text shadow
 *    in all browsers (opinionated).
 */

::-moz-selection {
  background-color: #b3d4fc; /* 1 */
  color: #000; /* 1 */
  text-shadow: none;
}

::selection {
  background-color: #b3d4fc; /* 1 */
  color: #000; /* 1 */
  text-shadow: none;
}

/* Embedded content
 * ========================================================================== */

/*
 * Change the alignment on media elements in all browers (opinionated).
 */

audio,
canvas,
iframe,
img,
svg,
video {
  vertical-align: middle;
}

/**
 * Add the correct display in IE 9-.
 */

audio,
video {
  display: inline-block;
}

/**
 * Add the correct display in iOS 4-7.
 */

audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Remove the border on images inside links in IE 10-.
 */

img {
  border-style: none;
}

/**
 * Change the fill color to match the text color in all browsers (opinionated).
 */

svg:not([fill]) {
  fill: currentColor;
}

/**
 * Hide the overflow in IE.
 */

svg:not(:root) {
  overflow: hidden;
}

/* Tabular data
 * ========================================================================== */

/**
 * Collapse border spacing in all browsers (opinionated).
 */

table {
  border-collapse: collapse;
}

/* Forms
 * ========================================================================== */

/**
 * Inherit styling in all browsers (opinionated).
 */

button,
input,
select,
textarea {
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

/**
 * Remove the margin in Safari.
 */

button,
input,
select {
  margin: 0;
}

/**
 * 1. Show the overflow in IE.
 * 2. Remove the inheritance of text transform in Edge, Firefox, and IE.
 */

button {
  overflow: visible; /* 1 */
  text-transform: none; /* 2 */
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */

button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}

/**
 * Correct the padding in Firefox.
 */

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * Show the overflow in Edge and IE.
 */

input {
  overflow: visible;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 */

legend {
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  white-space: normal; /* 1 */
}

/**
 * 1. Add the correct display in Edge and IE.
 * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
  display: inline-block; /* 1 */
  vertical-align: baseline; /* 2 */
}

/**
 * Remove the inheritance of text transform in Firefox.
 */

select {
  text-transform: none;
}

/**
 * 1. Remove the margin in Firefox and Safari.
 * 2. Remove the default vertical scrollbar in IE.
 * 3. Change the resize direction on textareas in all browsers (opinionated).
 */

textarea {
  margin: 0; /* 1 */
  overflow: auto; /* 2 */
  resize: vertical; /* 3 */
}

/**
 * Remove the padding in IE 10-.
 */

[type="checkbox"],
[type="radio"] {
  padding: 0;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */

[type="search"] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Safari.
 */

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

/**
 * Correct the text style of placeholders in Chrome, Edge, and Safari.
 */

::-webkit-input-placeholder {
  color: inherit;
  opacity: 0.54;
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */

::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/**
 * Remove the inner border and padding of focus outlines in Firefox.
 */

::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus outline styles unset by the previous rule in Firefox.
 */

:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/* Interactive
 * ========================================================================== */

/*
 * Add the correct display in Edge and IE.
 */

details {
  display: block;
}

/*
 * Add the correct styles in Edge, IE, and Safari.
 */

dialog {
  background-color: white;
  border: solid;
  color: black;
  display: block;
  height: -moz-fit-content;
  height: -webkit-fit-content;
  height: fit-content;
  left: 0;
  margin: auto;
  padding: 1em;
  position: absolute;
  right: 0;
  width: -moz-fit-content;
  width: -webkit-fit-content;
  width: fit-content;
}

dialog:not([open]) {
  display: none;
}

/*
 * Add the correct display in all browsers.
 */

summary {
  display: list-item;
}

/* Scripting
 * ========================================================================== */

/**
 * Add the correct display in IE 9-.
 */

canvas {
  display: inline-block;
}

/**
 * Add the correct display in IE.
 */

template {
  display: none;
}

/* User interaction
 * ========================================================================== */

/*
 * 1. Remove the tapping delay in IE 10.
 * 2. Remove the tapping delay on clickable elements
      in all browsers (opinionated).
 */

a,
area,
button,
input,
label,
select,
summary,
textarea,
[tabindex] { /* 1 */
  touch-action: manipulation; /* 2 */
}

/**
 * Add the correct display in IE 10-.
 */

[hidden] {
  display: none;
}

/* Accessibility
 * ========================================================================== */

/**
 * Change the cursor on busy elements in all browsers (opinionated).
 */

[aria-busy="true"] {
  cursor: progress;
}

/*
 * Change the cursor on control elements in all browsers (opinionated).
 */

[aria-controls] {
  cursor: pointer;
}

/*
 * Change the cursor on disabled, not-editable, or otherwise
 * inoperable elements in all browsers (opinionated).
 */

[aria-disabled="true"],
[disabled] {
  cursor: not-allowed;
}

/*
 * Change the display on visually hidden accessible elements
 * in all browsers (opinionated).
 */

[aria-hidden="false"][hidden]:not(:focus) {
  clip: rect(0, 0, 0, 0);
  display: inherit;
  position: absolute;
}
:root {
  --main-colour: #212227;
  --accent-colour: #d52bb5;
}

*,
*:before,
*:after {
  box-sizing: border-box;
}

html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-family: sans-serif;
  font-size: 16px;
  font-family: "acumin-pro", Helvetica, Arial, Roboto, sans-serif;
  line-height: 1.5;
  color: #212227;
  font-size: 18px;
}

@media (min-width: 560px) {
  html {
    font-size: calc(0.5073170732vw + 15.1590243902px);
  }
}

@media (min-width: 1216px) {
  html {
    font-size: 21.328px;
  }
}

body.light-branded .wrap {
  background-position: 50% 154px;
  background-repeat: repeat-x;
  background-image: url("/assets/img/bg-brand-light.svg");
}

body.themed .wrap {
  background-color: var(--main-colour);
  color: #fff;
  background-position: 50% 154px;
  background-repeat: repeat-x;
  background-image: url("/assets/img/bg-brand-blend.svg");
}

html.with-menu {
  height: 100vh;
  overflow: hidden;
}

h1,
h2,
h3,
h4,
h5,
.in-the-area__name {
  line-height: 1.1;
  letter-spacing: -0.0125em;
  font-weight: 800;
  margin: 0;
  color: var(--main-colour);
}

h1 {
  font-size: 39.68px;
}

@media (min-width: 560px) {
  h1 {
    font-size: calc(4.2170731707vw + 16.0643902439px);
  }
}

@media (min-width: 1216px) {
  h1 {
    font-size: 67.344px;
  }
}

h2 {
  font-size: 33.184px;
}

@media (min-width: 560px) {
  h2 {
    font-size: calc(2.6414634146vw + 18.391804878px);
  }
}

@media (min-width: 1216px) {
  h2 {
    font-size: 50.512px;
  }
}

h3,
.h3 {
  font-size: 27.648px;
}

@media (min-width: 560px) {
  h3,
  .h3 {
    font-size: calc(1.5634146341vw + 18.8928780488px);
  }
}

@media (min-width: 1216px) {
  h3,
  .h3 {
    font-size: 37.904px;
  }
}

h4 {
  font-size: 23.04px;
}

@media (min-width: 560px) {
  h4 {
    font-size: calc(0.8219512195vw + 18.4370731707px);
  }
}

@media (min-width: 1216px) {
  h4 {
    font-size: 28.432px;
  }
}

h5,
.in-the-area__name,
.h5 {
  font-size: 19.2px;
}

@media (min-width: 560px) {
  h5,
  .in-the-area__name,
  .h5 {
    font-size: calc(0.3243902439vw + 17.3834146341px);
  }
}

@media (min-width: 1216px) {
  h5,
  .in-the-area__name,
  .h5 {
    font-size: 21.328px;
  }
}

h6,
.venue-promo__label,
.prose h4 {
  color: var(--main-colour);
  font-size: 16px;
  text-transform: uppercase;
  line-height: 1.1;
  letter-spacing: 0.05em;
  font-weight: 800;
  margin: 0;
}

ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

p {
  margin: 0;
}

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

blockquote {
  padding: 0;
  margin: 0;
}

a,
a:visited,
a:hover {
  color: var(--link-colour, var(--accent-colour));
}

button {
  border: 0;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: transparent;
  cursor: pointer;
}

.lazyload {
  width: 100%;
}

.align-center {
  text-align: center !important;
}

.align-child {
  display: flex;
  justify-content: center;
}

.border-t {
  border-top: 1px solid rgba(33, 34, 39, 0.2) !important;
}

.border-b {
  border-bottom: 1px solid rgba(33, 34, 39, 0.2) !important;
}

.bg-white {
  background-color: #fff;
}

.cc {
  color: currentColor;
}

.dropcap p:first-child:first-letter {
  float: left;
  color: var(--dropcap-colour, var(--main-colour));
  font-size: 55.68px;
  font-weight: 800;
  line-height: 0.9;
  padding-right: 5px;
  margin-top: 0;
}

@media (min-width: 560px) {
  .dropcap p:first-child:first-letter {
    font-size: calc(6.656097561vw + 18.4058536585px);
  }
}

@media (min-width: 1216px) {
  .dropcap p:first-child:first-letter {
    font-size: 99.344px;
  }
}

@media (min-width: 560px) {
  .dropcap p:first-child:first-letter {
    margin-top: calc(-0.762195122vw + 4.2682926829px);
  }
}

@media (min-width: 1216px) {
  .dropcap p:first-child:first-letter {
    margin-top: -5px;
  }
}

.mx-1 {
  margin-top: 16px !important;
  margin-bottom: 16px !important;
}

@media (min-width: 560px) {
  .mx-1 {
    margin-top: calc(2.4390243902vw + 2.3414634146px) !important;
  }
}

@media (min-width: 1216px) {
  .mx-1 {
    margin-top: 32px !important;
  }
}

@media (min-width: 560px) {
  .mx-1 {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px) !important;
  }
}

@media (min-width: 1216px) {
  .mx-1 {
    margin-bottom: 32px !important;
  }
}

.mx-2 {
  margin-top: 32px !important;
  margin-bottom: 32px !important;
}

@media (min-width: 560px) {
  .mx-2 {
    margin-top: calc(4.8780487805vw + 4.6829268293px) !important;
  }
}

@media (min-width: 1216px) {
  .mx-2 {
    margin-top: 64px !important;
  }
}

@media (min-width: 560px) {
  .mx-2 {
    margin-bottom: calc(4.8780487805vw + 4.6829268293px) !important;
  }
}

@media (min-width: 1216px) {
  .mx-2 {
    margin-bottom: 64px !important;
  }
}

.mx-3 {
  margin-top: 48px !important;
  margin-bottom: 48px !important;
}

@media (min-width: 560px) {
  .mx-3 {
    margin-top: calc(7.3170731707vw + 7.0243902439px) !important;
  }
}

@media (min-width: 1216px) {
  .mx-3 {
    margin-top: 96px !important;
  }
}

@media (min-width: 560px) {
  .mx-3 {
    margin-bottom: calc(7.3170731707vw + 7.0243902439px) !important;
  }
}

@media (min-width: 1216px) {
  .mx-3 {
    margin-bottom: 96px !important;
  }
}

.mt-1 {
  margin-top: 16px !important;
}

@media (min-width: 560px) {
  .mt-1 {
    margin-top: calc(2.4390243902vw + 2.3414634146px) !important;
  }
}

@media (min-width: 1216px) {
  .mt-1 {
    margin-top: 32px !important;
  }
}

.mt-2 {
  margin-top: 32px !important;
}

@media (min-width: 560px) {
  .mt-2 {
    margin-top: calc(4.8780487805vw + 4.6829268293px) !important;
  }
}

@media (min-width: 1216px) {
  .mt-2 {
    margin-top: 64px !important;
  }
}

.mt-3 {
  margin-top: 48px !important;
}

@media (min-width: 560px) {
  .mt-3 {
    margin-top: calc(7.3170731707vw + 7.0243902439px) !important;
  }
}

@media (min-width: 1216px) {
  .mt-3 {
    margin-top: 96px !important;
  }
}

.mb-s {
  margin-bottom: 12px;
}

.mb-1 {
  margin-bottom: 16px !important;
}

@media (min-width: 560px) {
  .mb-1 {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px) !important;
  }
}

@media (min-width: 1216px) {
  .mb-1 {
    margin-bottom: 32px !important;
  }
}

.mb-2 {
  margin-bottom: 32px !important;
}

@media (min-width: 560px) {
  .mb-2 {
    margin-bottom: calc(4.8780487805vw + 4.6829268293px) !important;
  }
}

@media (min-width: 1216px) {
  .mb-2 {
    margin-bottom: 64px !important;
  }
}

.mb-3 {
  padding-bottom: 48px !important;
}

@media (min-width: 560px) {
  .mb-3 {
    padding-bottom: calc(7.3170731707vw + 7.0243902439px) !important;
  }
}

@media (min-width: 1216px) {
  .mb-3 {
    padding-bottom: 96px !important;
  }
}

.px-1 {
  padding-top: 16px !important;
  padding-bottom: 16px !important;
}

@media (min-width: 560px) {
  .px-1 {
    padding-top: calc(2.4390243902vw + 2.3414634146px) !important;
  }
}

@media (min-width: 1216px) {
  .px-1 {
    padding-top: 32px !important;
  }
}

@media (min-width: 560px) {
  .px-1 {
    padding-bottom: calc(2.4390243902vw + 2.3414634146px) !important;
  }
}

@media (min-width: 1216px) {
  .px-1 {
    padding-bottom: 32px !important;
  }
}

.px-2 {
  padding-top: 32px !important;
  padding-bottom: 32px !important;
}

@media (min-width: 560px) {
  .px-2 {
    padding-top: calc(4.8780487805vw + 4.6829268293px) !important;
  }
}

@media (min-width: 1216px) {
  .px-2 {
    padding-top: 64px !important;
  }
}

@media (min-width: 560px) {
  .px-2 {
    padding-bottom: calc(4.8780487805vw + 4.6829268293px) !important;
  }
}

@media (min-width: 1216px) {
  .px-2 {
    padding-bottom: 64px !important;
  }
}

.px-3 {
  padding-top: 48px !important;
  padding-bottom: 48px !important;
}

@media (min-width: 560px) {
  .px-3 {
    padding-top: calc(7.3170731707vw + 7.0243902439px) !important;
  }
}

@media (min-width: 1216px) {
  .px-3 {
    padding-top: 96px !important;
  }
}

@media (min-width: 560px) {
  .px-3 {
    padding-bottom: calc(7.3170731707vw + 7.0243902439px) !important;
  }
}

@media (min-width: 1216px) {
  .px-3 {
    padding-bottom: 96px !important;
  }
}

.pt-1 {
  padding-top: 16px !important;
}

@media (min-width: 560px) {
  .pt-1 {
    padding-top: calc(2.4390243902vw + 2.3414634146px) !important;
  }
}

@media (min-width: 1216px) {
  .pt-1 {
    padding-top: 32px !important;
  }
}

.pt-2 {
  padding-top: 32px !important;
}

@media (min-width: 560px) {
  .pt-2 {
    padding-top: calc(4.8780487805vw + 4.6829268293px) !important;
  }
}

@media (min-width: 1216px) {
  .pt-2 {
    padding-top: 64px !important;
  }
}

.pt-3 {
  padding-top: 48px !important;
}

@media (min-width: 560px) {
  .pt-3 {
    padding-top: calc(7.3170731707vw + 7.0243902439px) !important;
  }
}

@media (min-width: 1216px) {
  .pt-3 {
    padding-top: 96px !important;
  }
}

.pb-1 {
  padding-bottom: 16px !important;
}

@media (min-width: 560px) {
  .pb-1 {
    padding-bottom: calc(2.4390243902vw + 2.3414634146px) !important;
  }
}

@media (min-width: 1216px) {
  .pb-1 {
    padding-bottom: 32px !important;
  }
}

.pb-2 {
  padding-bottom: 32px !important;
}

@media (min-width: 560px) {
  .pb-2 {
    padding-bottom: calc(4.8780487805vw + 4.6829268293px) !important;
  }
}

@media (min-width: 1216px) {
  .pb-2 {
    padding-bottom: 64px !important;
  }
}

.pb-3 {
  padding-bottom: 48px !important;
}

@media (min-width: 560px) {
  .pb-3 {
    padding-bottom: calc(7.3170731707vw + 7.0243902439px) !important;
  }
}

@media (min-width: 1216px) {
  .pb-3 {
    padding-bottom: 96px !important;
  }
}

.py-1 {
  padding-left: 16px !important;
  padding-right: 16px !important;
}

@media (min-width: 560px) {
  .py-1 {
    padding-left: calc(2.4390243902vw + 2.3414634146px) !important;
  }
}

@media (min-width: 1216px) {
  .py-1 {
    padding-left: 32px !important;
  }
}

@media (min-width: 560px) {
  .py-1 {
    padding-right: calc(2.4390243902vw + 2.3414634146px) !important;
  }
}

@media (min-width: 1216px) {
  .py-1 {
    padding-right: 32px !important;
  }
}

.py-2 {
  padding-left: 32px !important;
  padding-right: 32px !important;
}

@media (min-width: 560px) {
  .py-2 {
    padding-left: calc(4.8780487805vw + 4.6829268293px) !important;
  }
}

@media (min-width: 1216px) {
  .py-2 {
    padding-left: 64px !important;
  }
}

@media (min-width: 560px) {
  .py-2 {
    padding-right: calc(4.8780487805vw + 4.6829268293px) !important;
  }
}

@media (min-width: 1216px) {
  .py-2 {
    padding-right: 64px !important;
  }
}

[grid] {
  display: grid;
  -webkit-column-gap: 16px;
          column-gap: 16px;
  --grid-tc: repeat(8, 1fr);
  grid-template-columns: var(--grid-tc);
  --grid-cs: 1;
  /* column start */
  --grid-ce: -1;
  /* column end */
}

@media (min-width: 560px) {
  [grid] {
    -webkit-column-gap: calc(2.4390243902vw + 2.3414634146px);
            column-gap: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  [grid] {
    -webkit-column-gap: 32px;
            column-gap: 32px;
  }
}

[grid][span],
[grid][span-s],
[grid][span-l] {
  display: grid;
}

[grid="1"] {
  --grid-tc: repeat(1, 1fr);
}

[grid="2"] {
  --grid-tc: repeat(2, 1fr);
}

[grid="3"] {
  --grid-tc: repeat(3, 1fr);
}

[grid="4"] {
  --grid-tc: repeat(4, 1fr);
}

[grid="5"] {
  --grid-tc: repeat(5, 1fr);
}

[grid="6"] {
  --grid-tc: repeat(6, 1fr);
}

[grid="7"] {
  --grid-tc: repeat(7, 1fr);
}

[grid="8"] {
  --grid-tc: repeat(8, 1fr);
}

[grid="9"] {
  --grid-tc: repeat(9, 1fr);
}

[grid="10"] {
  --grid-tc: repeat(10, 1fr);
}

[grid="11"] {
  --grid-tc: repeat(11, 1fr);
}

[grid="12"] {
  --grid-tc: repeat(12, 1fr);
}

/* span=start... */

[grid] > [span^="1"] {
  --grid-cs: 1;
}

[grid] > [span^="2"] {
  --grid-cs: 2;
}

[grid] > [span^="3"] {
  --grid-cs: 3;
}

[grid] > [span^="4"] {
  --grid-cs: 4;
}

[grid] > [span^="5"] {
  --grid-cs: 5;
}

[grid] > [span^="6"] {
  --grid-cs: 6;
}

[grid] > [span^="7"] {
  --grid-cs: 7;
}

[grid] > [span^="8"] {
  --grid-cs: 8;
}

[grid] > [span^="9"] {
  --grid-cs: 9;
}

[grid] > [span^="10"] {
  --grid-cs: 10;
}

[grid] > [span^="11"] {
  --grid-cs: 11;
}

[grid] > [span^="12"] {
  --grid-cs: 12;
}

/* span=...+width, span=...-end */

[grid] > [span$="+1"],
[grid] > [span="1"] {
  --grid-ce: 1;
}

[grid] > [span$="+2"],
[grid] > [span$="-1"],
[grid] > [span="2"] {
  --grid-ce: 2;
}

[grid] > [span$="+3"],
[grid] > [span$="-2"],
[grid] > [span="3"] {
  --grid-ce: 3;
}

[grid] > [span$="+4"],
[grid] > [span$="-3"],
[grid] > [span="4"] {
  --grid-ce: 4;
}

[grid] > [span$="+5"],
[grid] > [span$="-4"],
[grid] > [span="5"] {
  --grid-ce: 5;
}

[grid] > [span$="+6"],
[grid] > [span$="-5"],
[grid] > [span="6"] {
  --grid-ce: 6;
}

[grid] > [span$="+7"],
[grid] > [span$="-6"],
[grid] > [span="7"] {
  --grid-ce: 7;
}

[grid] > [span$="+8"],
[grid] > [span$="-7"],
[grid] > [span="8"] {
  --grid-ce: 8;
}

[grid] > [span$="+9"],
[grid] > [span$="-8"],
[grid] > [span="9"] {
  --grid-ce: 9;
}

[grid] > [span$="+10"],
[grid] > [span$="-9"],
[grid] > [span="10"] {
  --grid-ce: 10;
}

[grid] > [span$="+11"],
[grid] > [span$="-10"],
[grid] > [span="11"] {
  --grid-ce: 11;
}

[grid] > [span$="+12"],
[grid] > [span$="-11"],
[grid] > [span="12"] {
  --grid-ce: 12;
}

[grid] > [span$="-12"] {
  --grid-ce: 13;
}

/* connect vars */

[grid] > [span] {
  grid-column-end: span var(--grid-ce);
}

[grid] > [span*="+"],
[grid] > [span*="-"],
[grid] > [span*=".."] {
  grid-column-start: var(--grid-cs);
}

[grid] > [span*="-"],
[grid] > [span*=".."] {
  grid-column-end: var(--grid-ce);
}

[grid] > [span=row] {
  grid-column: 1/-1;
}

@media only screen and (min-width: 560px) {
  [grid-s="1"] {
    --grid-tc: repeat(1, 1fr);
  }

  [grid-s="2"] {
    --grid-tc: repeat(2, 1fr);
  }

  [grid-s="3"] {
    --grid-tc: repeat(3, 1fr);
  }

  [grid-s="4"] {
    --grid-tc: repeat(4, 1fr);
  }

  [grid-s="5"] {
    --grid-tc: repeat(5, 1fr);
  }

  [grid-s="6"] {
    --grid-tc: repeat(6, 1fr);
  }

  [grid-s="7"] {
    --grid-tc: repeat(7, 1fr);
  }

  [grid-s="8"] {
    --grid-tc: repeat(8, 1fr);
  }

  [grid-s="9"] {
    --grid-tc: repeat(9, 1fr);
  }

  [grid-s="10"] {
    --grid-tc: repeat(10, 1fr);
  }

  [grid-s="11"] {
    --grid-tc: repeat(11, 1fr);
  }

  [grid-s="12"] {
    --grid-tc: repeat(12, 1fr);
  }

  /* span-s=start... */

  [grid] > [span-s^="1"] {
    --grid-cs: 1;
  }

  [grid] > [span-s^="2"] {
    --grid-cs: 2;
  }

  [grid] > [span-s^="3"] {
    --grid-cs: 3;
  }

  [grid] > [span-s^="4"] {
    --grid-cs: 4;
  }

  [grid] > [span-s^="5"] {
    --grid-cs: 5;
  }

  [grid] > [span-s^="6"] {
    --grid-cs: 6;
  }

  [grid] > [span-s^="7"] {
    --grid-cs: 7;
  }

  [grid] > [span-s^="8"] {
    --grid-cs: 8;
  }

  [grid] > [span-s^="9"] {
    --grid-cs: 9;
  }

  [grid] > [span-s^="10"] {
    --grid-cs: 10;
  }

  [grid] > [span-s^="11"] {
    --grid-cs: 11;
  }

  [grid] > [span-s^="12"] {
    --grid-cs: 12;
  }

  /* span-s=...+width, span-s=...-end */

  [grid] > [span-s$="+1"],
  [grid] > [span-s="1"] {
    --grid-ce: 1;
  }

  [grid] > [span-s$="+2"],
  [grid] > [span-s$="-1"],
  [grid] > [span-s="2"] {
    --grid-ce: 2;
  }

  [grid] > [span-s$="+3"],
  [grid] > [span-s$="-2"],
  [grid] > [span-s="3"] {
    --grid-ce: 3;
  }

  [grid] > [span-s$="+4"],
  [grid] > [span-s$="-3"],
  [grid] > [span-s="4"] {
    --grid-ce: 4;
  }

  [grid] > [span-s$="+5"],
  [grid] > [span-s$="-4"],
  [grid] > [span-s="5"] {
    --grid-ce: 5;
  }

  [grid] > [span-s$="+6"],
  [grid] > [span-s$="-5"],
  [grid] > [span-s="6"] {
    --grid-ce: 6;
  }

  [grid] > [span-s$="+7"],
  [grid] > [span-s$="-6"],
  [grid] > [span-s="7"] {
    --grid-ce: 7;
  }

  [grid] > [span-s$="+8"],
  [grid] > [span-s$="-7"],
  [grid] > [span-s="8"] {
    --grid-ce: 8;
  }

  [grid] > [span-s$="+9"],
  [grid] > [span-s$="-8"],
  [grid] > [span-s="9"] {
    --grid-ce: 9;
  }

  [grid] > [span-s$="+10"],
  [grid] > [span-s$="-9"],
  [grid] > [span-s="10"] {
    --grid-ce: 10;
  }

  [grid] > [span-s$="+11"],
  [grid] > [span-s$="-10"],
  [grid] > [span-s="11"] {
    --grid-ce: 11;
  }

  [grid] > [span-s$="+12"],
  [grid] > [span-s$="-11"],
  [grid] > [span-s="12"] {
    --grid-ce: 12;
  }

  [grid] > [span-s$="-12"] {
    --grid-ce: 13;
  }

  /* connect vars */

  [grid] > [span-s] {
    grid-column-end: span var(--grid-ce);
  }

  [grid] > [span-s*="+"],
  [grid] > [span-s*="-"],
  [grid] > [span-s*=".."] {
    grid-column-start: var(--grid-cs);
  }

  [grid] > [span-s*="-"],
  [grid] > [span-s*=".."] {
    grid-column-end: var(--grid-ce);
  }

  [grid] > [span-s=row] {
    grid-column: 1/-1;
  }
}

@media only screen and (min-width: 800px) {
  [grid-m="1"] {
    --grid-tc: repeat(1, 1fr);
  }

  [grid-m="2"] {
    --grid-tc: repeat(2, 1fr);
  }

  [grid-m="3"] {
    --grid-tc: repeat(3, 1fr);
  }

  [grid-m="4"] {
    --grid-tc: repeat(4, 1fr);
  }

  [grid-m="5"] {
    --grid-tc: repeat(5, 1fr);
  }

  [grid-m="6"] {
    --grid-tc: repeat(6, 1fr);
  }

  [grid-m="7"] {
    --grid-tc: repeat(7, 1fr);
  }

  [grid-m="8"] {
    --grid-tc: repeat(8, 1fr);
  }

  [grid-m="9"] {
    --grid-tc: repeat(9, 1fr);
  }

  [grid-m="10"] {
    --grid-tc: repeat(10, 1fr);
  }

  [grid-m="11"] {
    --grid-tc: repeat(11, 1fr);
  }

  [grid-m="12"] {
    --grid-tc: repeat(12, 1fr);
  }

  /* span-m=start... */

  [grid] > [span-m^="1"] {
    --grid-cs: 1;
  }

  [grid] > [span-m^="2"] {
    --grid-cs: 2;
  }

  [grid] > [span-m^="3"] {
    --grid-cs: 3;
  }

  [grid] > [span-m^="4"] {
    --grid-cs: 4;
  }

  [grid] > [span-m^="5"] {
    --grid-cs: 5;
  }

  [grid] > [span-m^="6"] {
    --grid-cs: 6;
  }

  [grid] > [span-m^="7"] {
    --grid-cs: 7;
  }

  [grid] > [span-m^="8"] {
    --grid-cs: 8;
  }

  [grid] > [span-m^="9"] {
    --grid-cs: 9;
  }

  [grid] > [span-m^="10"] {
    --grid-cs: 10;
  }

  [grid] > [span-m^="11"] {
    --grid-cs: 11;
  }

  [grid] > [span-m^="12"] {
    --grid-cs: 12;
  }

  /* span-m=...+width, span-m=...-end */

  [grid] > [span-m$="+1"],
  [grid] > [span-m="1"] {
    --grid-ce: 1;
  }

  [grid] > [span-m$="+2"],
  [grid] > [span-m$="-1"],
  [grid] > [span-m="2"] {
    --grid-ce: 2;
  }

  [grid] > [span-m$="+3"],
  [grid] > [span-m$="-2"],
  [grid] > [span-m="3"] {
    --grid-ce: 3;
  }

  [grid] > [span-m$="+4"],
  [grid] > [span-m$="-3"],
  [grid] > [span-m="4"] {
    --grid-ce: 4;
  }

  [grid] > [span-m$="+5"],
  [grid] > [span-m$="-4"],
  [grid] > [span-m="5"] {
    --grid-ce: 5;
  }

  [grid] > [span-m$="+6"],
  [grid] > [span-m$="-5"],
  [grid] > [span-m="6"] {
    --grid-ce: 6;
  }

  [grid] > [span-m$="+7"],
  [grid] > [span-m$="-6"],
  [grid] > [span-m="7"] {
    --grid-ce: 7;
  }

  [grid] > [span-m$="+8"],
  [grid] > [span-m$="-7"],
  [grid] > [span-m="8"] {
    --grid-ce: 8;
  }

  [grid] > [span-m$="+9"],
  [grid] > [span-m$="-8"],
  [grid] > [span-m="9"] {
    --grid-ce: 9;
  }

  [grid] > [span-m$="+10"],
  [grid] > [span-m$="-9"],
  [grid] > [span-m="10"] {
    --grid-ce: 10;
  }

  [grid] > [span-m$="+11"],
  [grid] > [span-m$="-10"],
  [grid] > [span-m="11"] {
    --grid-ce: 11;
  }

  [grid] > [span-m$="+12"],
  [grid] > [span-m$="-11"],
  [grid] > [span-m="12"] {
    --grid-ce: 12;
  }

  [grid] > [span-m$="-12"] {
    --grid-ce: 13;
  }

  /* connect vars */

  [grid] > [span-m] {
    grid-column-end: span var(--grid-ce);
  }

  [grid] > [span-m*="+"],
  [grid] > [span-m*="-"],
  [grid] > [span-m*=".."] {
    grid-column-start: var(--grid-cs);
  }

  [grid] > [span-m*="-"],
  [grid] > [span-m*=".."] {
    grid-column-end: var(--grid-ce);
  }

  [grid] > [span-m=row] {
    grid-column: 1/-1;
  }
}

@media only screen and (min-width: 1024px) {
  [grid-l="1"] {
    --grid-tc: repeat(1, 1fr);
  }

  [grid-l="2"] {
    --grid-tc: repeat(2, 1fr);
  }

  [grid-l="3"] {
    --grid-tc: repeat(3, 1fr);
  }

  [grid-l="4"] {
    --grid-tc: repeat(4, 1fr);
  }

  [grid-l="5"] {
    --grid-tc: repeat(5, 1fr);
  }

  [grid-l="6"] {
    --grid-tc: repeat(6, 1fr);
  }

  [grid-l="7"] {
    --grid-tc: repeat(7, 1fr);
  }

  [grid-l="8"] {
    --grid-tc: repeat(8, 1fr);
  }

  [grid-l="9"] {
    --grid-tc: repeat(9, 1fr);
  }

  [grid-l="10"] {
    --grid-tc: repeat(10, 1fr);
  }

  [grid-l="11"] {
    --grid-tc: repeat(11, 1fr);
  }

  [grid-l="12"] {
    --grid-tc: repeat(12, 1fr);
  }

  /* span-l=start... */

  [grid] > [span-l^="1"] {
    --grid-cs: 1;
  }

  [grid] > [span-l^="2"] {
    --grid-cs: 2;
  }

  [grid] > [span-l^="3"] {
    --grid-cs: 3;
  }

  [grid] > [span-l^="4"] {
    --grid-cs: 4;
  }

  [grid] > [span-l^="5"] {
    --grid-cs: 5;
  }

  [grid] > [span-l^="6"] {
    --grid-cs: 6;
  }

  [grid] > [span-l^="7"] {
    --grid-cs: 7;
  }

  [grid] > [span-l^="8"] {
    --grid-cs: 8;
  }

  [grid] > [span-l^="9"] {
    --grid-cs: 9;
  }

  [grid] > [span-l^="10"] {
    --grid-cs: 10;
  }

  [grid] > [span-l^="11"] {
    --grid-cs: 11;
  }

  [grid] > [span-l^="12"] {
    --grid-cs: 12;
  }

  /* span-l=...+width, span-l=...-end */

  [grid] > [span-l$="+1"],
  [grid] > [span-l="1"] {
    --grid-ce: 1;
  }

  [grid] > [span-l$="+2"],
  [grid] > [span-l$="-1"],
  [grid] > [span-l="2"] {
    --grid-ce: 2;
  }

  [grid] > [span-l$="+3"],
  [grid] > [span-l$="-2"],
  [grid] > [span-l="3"] {
    --grid-ce: 3;
  }

  [grid] > [span-l$="+4"],
  [grid] > [span-l$="-3"],
  [grid] > [span-l="4"] {
    --grid-ce: 4;
  }

  [grid] > [span-l$="+5"],
  [grid] > [span-l$="-4"],
  [grid] > [span-l="5"] {
    --grid-ce: 5;
  }

  [grid] > [span-l$="+6"],
  [grid] > [span-l$="-5"],
  [grid] > [span-l="6"] {
    --grid-ce: 6;
  }

  [grid] > [span-l$="+7"],
  [grid] > [span-l$="-6"],
  [grid] > [span-l="7"] {
    --grid-ce: 7;
  }

  [grid] > [span-l$="+8"],
  [grid] > [span-l$="-7"],
  [grid] > [span-l="8"] {
    --grid-ce: 8;
  }

  [grid] > [span-l$="+9"],
  [grid] > [span-l$="-8"],
  [grid] > [span-l="9"] {
    --grid-ce: 9;
  }

  [grid] > [span-l$="+10"],
  [grid] > [span-l$="-9"],
  [grid] > [span-l="10"] {
    --grid-ce: 10;
  }

  [grid] > [span-l$="+11"],
  [grid] > [span-l$="-10"],
  [grid] > [span-l="11"] {
    --grid-ce: 11;
  }

  [grid] > [span-l$="+12"],
  [grid] > [span-l$="-11"],
  [grid] > [span-l="12"] {
    --grid-ce: 12;
  }

  [grid] > [span-l$="-12"] {
    --grid-ce: 13;
  }

  /* connect vars */

  [grid] > [span-l] {
    grid-column-end: span var(--grid-ce);
  }

  [grid] > [span-l*="+"],
  [grid] > [span-l*="-"],
  [grid] > [span-l*=".."] {
    grid-column-start: var(--grid-cs);
  }

  [grid] > [span-l*="-"],
  [grid] > [span-l*=".."] {
    grid-column-end: var(--grid-ce);
  }

  [grid] > [span-l=row] {
    grid-column: 1/-1;
  }
}

/* .debug can be added to a [grid]to visualize its effective cells */

.debug [grid] > * {
  --color: rgba(248, 110, 91, 0.3);
  background-image: linear-gradient(to bottom, var(--color) 0%, var(--color) 100%);
}

.debug [grid] > :nth-child(6n+2) {
  --color: rgba(103, 126, 208, 0.3);
}

.debug [grid] > :nth-child(6n+3) {
  --color: rgba(224, 174, 72, 0.3);
}

.debug [grid] > :nth-child(6n+4) {
  --color: rgba(77, 214, 115, 0.3);
}

.debug [grid] > :nth-child(6n+5) {
  --color: rgba(217, 103, 219, 0.3);
}

.debug [grid] > :nth-child(6n+6) {
  --color: rgba(94, 204, 211, 0.3);
}

.debug [grid] > :nth-child(6n+7) {
  --color: rgba(248, 110, 91, 0.3);
}

.u-relative {
  position: relative;
}

:root {
  --fui-color: #212227 !important;
  --fui-border: 0 solid #FFFFFF;
  --fui-border-radius: 0;
  --fui-border-color: #FFFFFF;
  --fui-focus-border-color: #d52bb5;
  --fui-focus-shadow: 0 0 0 3px rgba(213, 43, 181, 0.25);
  --fui-error-font-size: 1rem;
  --fui-label-font-size: 1rem;
  --fui-label-font-weight: 700 !important;
  --fui-label-color: #212227;
  --fui-instructions-font-size: 1rem;
  --fui-check-font-size: 1rem;
  --fui-check-bg-color: #f0f1f4;
  --fui-check-bg-color-checked: #d52bb5;
  --fui-check-border-color-checked: #d52bb5;
  --fui-check-border-color-focus: #d52bb5;
  --fui-check-box-shadow-focus: 0 0 0 3px rgba(213, 43, 181, 0.25);
  --fui-check-check-bg-size: 12px auto !important;
  --fui-input-font-size: 1rem;
  --fui-input-border-radius: 0;
  --fui-input-border-color-focus: #d52bb5;
  --fui-input-box-shadow-focus: 0 0 0 3px rgba(213, 43, 181, 0.25);
}

.fui-checkbox label {
  color: var(--fui-label-color);
  font-weight: var(--fui-label-font-weight);
}

.fui-layout-wrap {
  display: flex;
  justify-content: stretch;
  width: 100%;
  background: #fff;
  margin-top: 0.5rem;
}

.fui-layout-wrap .fui-radio {
  flex: 1;
  margin-bottom: 0 !important;
}

.fui-layout-wrap .fui-radio + .fui-radio {
  border-left: 1px solid #f6f6f6;
}

.fui-layout-wrap .fui-radio input {
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(50%);
          clip-path: inset(50%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.fui-layout-wrap .fui-radio label {
  padding: 0.5rem;
  cursor: pointer;
  display: block;
  text-align: center;
}

.fui-layout-wrap .fui-radio label::before {
  content: none;
}

.fui-layout-wrap .fui-radio input:checked + label,
.fui-layout-wrap .fui-radio input:focus + label,
.fui-layout-wrap .fui-radio label:hover {
  box-shadow: inset 0 0 0 2px #d52bb5;
}

.fui-layout-wrap .fui-radio input:checked + label {
  color: #d52bb5;
}

.address--block {
  background-color: var(--main-colour-tint, #f6f6f6);
  padding: 16px;
  border-left: 4px solid var(--main-colour);
}

@media (min-width: 560px) {
  .address--block {
    padding: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .address--block {
    padding: 32px;
  }
}

.bullet-list {
  margin-left: 30px;
  list-style: disc;
}

.bullet-list li {
  margin-bottom: 0.5em;
}

.button {
  font-size: 21px;
  border: 0;
  font-weight: 700;
  text-decoration: none;
  color: var(--button-text-colour, #fff);
  background-color: var(--accent-colour);
  display: inline-block;
  padding-top: 8px;
  padding-bottom: 12px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  white-space: nowrap;
  cursor: pointer;
  border-radius: 2em;
  transition: all 0.2s ease;
  text-align: center;
  padding-left: 32px;
  padding-right: 32px;
}

@media (min-width: 560px) {
  .button {
    padding-left: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .button {
    padding-left: 64px;
  }
}

@media (min-width: 560px) {
  .button {
    padding-right: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .button {
    padding-right: 64px;
  }
}

.button:visited,
.button:hover,
.button:active {
  color: var(--button-text-colour, #fff);
}

.button--squared {
  border-radius: 0;
}

.button--small {
  font-size: 16px;
  padding: 0.25em 1em;
}

.button--inverted {
  color: currentColor;
  background-color: #fff;
}

.button--inverted:visited,
.button--inverted:hover,
.button--inverted:active {
  color: currentColor;
}

.button--border {
  color: var(--accent-color);
  border: 2px solid;
  margin-top: 0.75rem;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 0.25rem 1rem;
  min-height: 34px;
  font-size: 16px;
  font-weight: 700;
  border-radius: 32px;
}

.button.button--inverted {
  color: var(--accent-colour);
  background-color: #fff;
}

.button.button--inverted:visited,
.button.button--inverted:hover,
.button.button--inverted:active {
  color: var(--accent-colour);
}

.button.button--inverted-accent {
  color: #FFF;
  background-color: var(--accent-colour);
}

.button.button--inverted-accent:visited,
.button.button--inverted-accent:hover,
.button.button--inverted-accent:active {
  background: var(--accent-colour);
  color: #FFF;
}

.faq-title {
  margin: 0;
  font-size: 19.2px;
}

@media (min-width: 560px) {
  .faq-title {
    font-size: calc(0.3243902439vw + 17.3834146341px);
  }
}

@media (min-width: 1216px) {
  .faq-title {
    font-size: 21.328px;
  }
}

.faq-title:not(:first-child) {
  border-top: 1px solid #CCC;
}

.faq-title a {
  position: relative;
  color: inherit;
  display: block;
  padding: 1rem 2rem 0 0;
  text-decoration: none;
  font-weight: 700;
}

.faq-title a:after {
  content: "";
  width: 8px;
  height: 8px;
  border-right: 2px solid #212227;
  border-bottom: 2px solid #212227;
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(25%) translateX(-50%) rotate(45deg);
          transform: translateY(25%) translateX(-50%) rotate(45deg);
  transition: 300ms -webkit-transform;
  transition: 300ms transform;
  transition: 300ms transform, 300ms -webkit-transform;
}

.faq-title:not(:first-child) {
  margin-top: 1rem;
}

.faq-title:not(:target):not([aria-expanded=true]) + *,
.faq-title.js-enhanced:not([aria-expanded=true]) + * {
  display: none;
}

.faq-title:target a:after,
.faq-title.js-enhanced[aria-expanded=true] a:after {
  -webkit-transform: translateX(-50%) translateY(50%) rotate(-135deg);
          transform: translateX(-50%) translateY(50%) rotate(-135deg);
}

.faq-title + * {
  padding-top: 1rem;
}

.icon {
  width: 48px;
  height: 48px;
  display: inline-block;
}

.icon svg * {
  fill: currentColor;
}

.icon .stroke {
  stroke: currentColor;
}

.imgset {
  width: 100%;
}

.input {
  border: 0;
  padding: 16px 16px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

.input[type=checkbox] {
  -webkit-appearance: checkbox;
     -moz-appearance: checkbox;
          appearance: checkbox;
}

.input[type=radio] {
  -webkit-appearance: radio;
     -moz-appearance: radio;
          appearance: radio;
}

.label {
  font-weight: bold;
}

.label em {
  color: #d52bb5;
  font-style: normal;
  display: inline-block;
  margin-left: 5px;
}

.label.lone {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: normal;
}

.logo {
  display: inline-block;
}

.logo .swoosh {
  fill: var(--accent-colour);
}

.panel {
  background: #f6f6f6;
  color: #212227;
  text-align: left;
  position: relative;
}

.panel:not(.panel--unpadded) {
  padding: 16px;
}

@media (min-width: 560px) {
  .panel:not(.panel--unpadded) {
    padding: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .panel:not(.panel--unpadded) {
    padding: 32px;
  }
}

.panel--pullup {
  margin-top: -96px;
}

@media all and (min-width: 560px) {
  .panel--split {
    display: flex;
  }

  .panel--split > * {
    width: 50%;
  }

  .panel--split > :first-child {
    padding-right: 16px;
  }
}

@media (min-width: 560px) and (min-width: 560px) {
  .panel--split > :first-child {
    padding-right: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 560px) and (min-width: 1216px) {
  .panel--split > :first-child {
    padding-right: 32px;
  }
}

@media all and (min-width: 560px) {
  .panel--split > :last-child {
    padding-left: 16px;
  }
}

@media (min-width: 560px) and (min-width: 560px) {
  .panel--split > :last-child {
    padding-left: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 560px) and (min-width: 1216px) {
  .panel--split > :last-child {
    padding-left: 32px;
  }
}

@media all and (max-width: 560px) {
  .panel--pullout {
    margin-left: -16px;
    margin-right: -16px;
    padding-left: 16px;
    padding-right: 16px;
  }
}

@media (max-width: 560px) and (min-width: 560px) {
  .panel--pullout {
    margin-left: calc(-2.4390243902vw - 2.3414634146px);
  }
}

@media (max-width: 560px) and (min-width: 1216px) {
  .panel--pullout {
    margin-left: -32px;
  }
}

@media (max-width: 560px) and (min-width: 560px) {
  .panel--pullout {
    margin-right: calc(-2.4390243902vw - 2.3414634146px);
  }
}

@media (max-width: 560px) and (min-width: 1216px) {
  .panel--pullout {
    margin-right: -32px;
  }
}

@media (max-width: 560px) and (min-width: 560px) {
  .panel--pullout {
    padding-left: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (max-width: 560px) and (min-width: 1216px) {
  .panel--pullout {
    padding-left: 32px;
  }
}

@media (max-width: 560px) and (min-width: 560px) {
  .panel--pullout {
    padding-right: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (max-width: 560px) and (min-width: 1216px) {
  .panel--pullout {
    padding-right: 32px;
  }
}

div.profile-img {
  background-color: #ddd;
  width: 100%;
  height: 0;
  padding-bottom: 100%;
}

.profile-img--full {
  width: 100%;
}

.profile-img--colorized {
  mix-blend-mode: screen;
}

.prose > :first-child {
  margin-top: 0;
}

.prose > :last-child {
  margin-bottom: 0;
}

.prose p,
.prose ul,
.prose ol {
  margin-bottom: 1em;
}

.prose ul {
  margin-left: 30px;
  list-style: disc;
}

.prose ol {
  margin-left: 30px;
  list-style: decimal;
}

.prose h2 {
  font-size: 23.04px;
  margin-top: 1.5em;
  margin-bottom: 1em;
}

@media (min-width: 560px) {
  .prose h2 {
    font-size: calc(0.8219512195vw + 18.4370731707px);
  }
}

@media (min-width: 1216px) {
  .prose h2 {
    font-size: 28.432px;
  }
}

.prose h3 {
  font-size: 19.2px;
  margin-top: 1.5em;
  margin-bottom: 1em;
}

@media (min-width: 560px) {
  .prose h3 {
    font-size: calc(0.3243902439vw + 17.3834146341px);
  }
}

@media (min-width: 1216px) {
  .prose h3 {
    font-size: 21.328px;
  }
}

.prose h4 {
  margin-top: 1em;
  margin-bottom: 1em;
}

.radio-buttons {
  display: flex;
  justify-content: stretch;
  width: 100%;
  background: #fff;
  margin-top: 0.5rem;
}

.radio-buttons input {
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(50%);
          clip-path: inset(50%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.radio-buttons label {
  padding: 0.5rem;
  cursor: pointer;
  display: block;
  text-align: center;
}

.radio-buttons input:checked + label,
.radio-buttons input:focus + label,
.radio-buttons label:hover {
  box-shadow: inset 0 0 0 2px #d52bb5;
}

.radio-buttons li {
  flex: 1;
}

.radio-buttons li + li {
  border-left: 1px solid #f6f6f6;
}

.radio-buttons input:checked + label {
  color: #d52bb5;
}

textarea {
  border: 0;
  padding: 16px 16px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

.video {
  display: block;
  margin: 0;
}

.video__player {
  width: 100%;
  position: relative;
  padding-bottom: 56.25%;
  /* 16:9 */
  height: 0;
  margin: 0;
  background-color: #eee;
}

.video__iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.video__caption {
  font-size: 16px;
  display: block;
  margin-top: 8px;
}

.video__caption > * {
  display: block;
}

.aside__title {
  margin-bottom: 16px;
}

@media (min-width: 560px) {
  .aside__title {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .aside__title {
    margin-bottom: 32px;
  }
}

.aside__content {
  font-size: 16px;
}

.aside + .aside {
  margin-top: 32px;
}

@media (min-width: 560px) {
  .aside + .aside {
    margin-top: calc(2.4390243902vw + 18.3414634146px);
  }
}

@media (min-width: 1216px) {
  .aside + .aside {
    margin-top: 48px;
  }
}

.banner-block {
  background-color: var(--main-colour-shade, var(--main-colour));
  color: #fff;
  padding: 32px;
}

@media (min-width: 560px) {
  .banner-block {
    padding: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .banner-block {
    padding: 64px;
  }
}

.banner-block--emergency .banner-block {
  background-color: #fff;
  color: #3a3b4f;
}

.banner-block--emergency .banner-block__content {
  max-width: 750px;
}

.banner-block--emergency .banner-block__title {
  color: inherit;
}

.banner-block--emergency-secondary .banner-block__content {
  text-align: left;
}

.banner-block--emergency-secondary .banner-block__content h2 {
  font-size: 33.184px;
  margin-bottom: 16px;
}

@media (min-width: 560px) {
  .banner-block--emergency-secondary .banner-block__content h2 {
    font-size: calc(2.6414634146vw + 18.391804878px);
  }
}

@media (min-width: 1216px) {
  .banner-block--emergency-secondary .banner-block__content h2 {
    font-size: 50.512px;
  }
}

@media (min-width: 560px) {
  .banner-block--emergency-secondary .banner-block__content h2 {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .banner-block--emergency-secondary .banner-block__content h2 {
    margin-bottom: 32px;
  }
}

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

.banner-block__title {
  margin-bottom: 16px;
  color: #fff;
}

@media (min-width: 560px) {
  .banner-block__title {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .banner-block__title {
    margin-bottom: 32px;
  }
}

.banner-block__subtitle {
  color: inherit;
  font-size: 19.2px;
  margin-bottom: 16px;
}

@media (min-width: 560px) {
  .banner-block__subtitle {
    font-size: calc(0.3243902439vw + 17.3834146341px);
  }
}

@media (min-width: 1216px) {
  .banner-block__subtitle {
    font-size: 21.328px;
  }
}

@media (min-width: 560px) {
  .banner-block__subtitle {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .banner-block__subtitle {
    margin-bottom: 32px;
  }
}

.banner-block .button {
  margin-top: 16px;
}

@media (min-width: 560px) {
  .banner-block .button {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .banner-block .button {
    margin-top: 32px;
  }
}

.card-set + .card-set,
.card-set__card + .card-set__card {
  margin-top: 16px;
}

@media (min-width: 560px) {
  .card-set + .card-set,
  .card-set__card + .card-set__card {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .card-set + .card-set,
  .card-set__card + .card-set__card {
    margin-top: 32px;
  }
}

@media all and (min-width: 560px) {
  .card-set--double .card-set__card + .card-set__card {
    margin-top: 0;
  }
}

@media all and (min-width: 560px) {
  .card-set--triple .card-set__card:nth-child(1),
  .card-set--triple .card-set__card:nth-child(2) {
    margin-top: 0;
  }
}

@media all and (min-width: 800px) {
  .card-set--triple .card-set__card + .card-set__card {
    margin-top: 0;
  }
}

.conference-intro {
  --content-bg: #FFF;
  display: flex;
  flex-direction: column;
}

.conference-intro .prose {
  padding-top: 32px;
  padding-bottom: 32px;
}

@media (min-width: 560px) {
  .conference-intro .prose {
    padding-top: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .conference-intro .prose {
    padding-top: 64px;
  }
}

@media (min-width: 560px) {
  .conference-intro .prose {
    padding-bottom: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .conference-intro .prose {
    padding-bottom: 64px;
  }
}

.conference-intro__img {
  background-color: var(--main-colour);
}

.conference-intro__img img {
  mix-blend-mode: screen;
}

@media all and (min-width: 560px) {
  .conference-intro .prose {
    padding: 32px;
  }
}

@media (min-width: 560px) and (min-width: 560px) {
  .conference-intro .prose {
    padding: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 560px) and (min-width: 1216px) {
  .conference-intro .prose {
    padding: 64px;
  }
}

@media all and (min-width: 800px) {
  .conference-intro {
    flex-direction: row;
    align-items: flex-start;
  }

  .conference-intro__text {
    width: 50%;
    margin-top: 32px;
    margin-left: 32px;
    margin-right: -32px;
    position: relative;
    z-index: 2;
  }
}

@media (min-width: 800px) and (min-width: 560px) {
  .conference-intro__text {
    margin-top: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 800px) and (min-width: 1216px) {
  .conference-intro__text {
    margin-top: 64px;
  }
}

@media (min-width: 800px) and (min-width: 560px) {
  .conference-intro__text {
    margin-left: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 800px) and (min-width: 1216px) {
  .conference-intro__text {
    margin-left: 64px;
  }
}

@media (min-width: 800px) and (min-width: 560px) {
  .conference-intro__text {
    margin-right: calc(-4.8780487805vw - 4.6829268293px);
  }
}

@media (min-width: 800px) and (min-width: 1216px) {
  .conference-intro__text {
    margin-right: -64px;
  }
}

@media all and (min-width: 800px) {
  .conference-intro .prose {
    background-color: var(--content-bg);
  }
}

@media all and (min-width: 800px) {
  .conference-intro--alt {
    --content-bg: #f6f6f6;
  }
}

@media all and (min-width: 800px) {
  .conference-intro__img {
    width: 50%;
    z-index: 1;
    position: relative;
  }
}

@media all and (min-width: 800px) {
  .conference-intro--full .conference-intro__text {
    margin-left: 0;
    margin-right: -80px;
  }
}

@media all and (min-width: 800px) {
  .conference-intro--full .conference-intro__img {
    width: calc(50% + 80px);
  }
}

@media all and (min-width: 800px) {
  .conference-intro--flip {
    flex-direction: row-reverse;
  }
}

@media all and (min-width: 800px) {
  .conference-intro--flip .conference-intro__text {
    margin-left: -80px;
    margin-right: 0;
  }
}

.content__block + .content__block {
  margin-top: 32px;
}

@media (min-width: 560px) {
  .content__block + .content__block {
    margin-top: calc(2.4390243902vw + 18.3414634146px);
  }
}

@media (min-width: 1216px) {
  .content__block + .content__block {
    margin-top: 48px;
  }
}

.content__subsection + .content__subsection {
  margin-top: 32px;
}

@media (min-width: 560px) {
  .content__subsection + .content__subsection {
    margin-top: calc(2.4390243902vw + 18.3414634146px);
  }
}

@media (min-width: 1216px) {
  .content__subsection + .content__subsection {
    margin-top: 48px;
  }
}

.content--narrow .content__block > h2 {
  font-size: 23.04px;
  margin-bottom: 16px;
}

@media (min-width: 560px) {
  .content--narrow .content__block > h2 {
    font-size: calc(0.8219512195vw + 18.4370731707px);
  }
}

@media (min-width: 1216px) {
  .content--narrow .content__block > h2 {
    font-size: 28.432px;
  }
}

.content--wide .content__block + .content__block {
  margin-top: 48px;
}

@media (min-width: 560px) {
  .content--wide .content__block + .content__block {
    margin-top: calc(4.8780487805vw + 20.6829268293px);
  }
}

@media (min-width: 1216px) {
  .content--wide .content__block + .content__block {
    margin-top: 80px;
  }
}

.content--wide .content__block--image + .content__block--image-pair,
.content--wide .content__block--image-pair + .content__block--image {
  margin-top: 16px;
}

@media (min-width: 560px) {
  .content--wide .content__block--image + .content__block--image-pair,
  .content--wide .content__block--image-pair + .content__block--image {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .content--wide .content__block--image + .content__block--image-pair,
  .content--wide .content__block--image-pair + .content__block--image {
    margin-top: 32px;
  }
}

.content--wide .content__block > h2,
.content--wide .content__block > h3,
.content--wide .content__subsection > h3 {
  text-align: center;
  margin-bottom: 16px;
}

@media (min-width: 560px) {
  .content--wide .content__block > h2,
  .content--wide .content__block > h3,
  .content--wide .content__subsection > h3 {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .content--wide .content__block > h2,
  .content--wide .content__block > h3,
  .content--wide .content__subsection > h3 {
    margin-bottom: 32px;
  }
}

.content--wide .content__block--venue .prose {
  position: relative;
  z-index: 2;
}

.content--wide .content__block > h2 + .panel {
  margin-top: 32px;
}

@media (min-width: 560px) {
  .content--wide .content__block > h2 + .panel {
    margin-top: calc(2.4390243902vw + 18.3414634146px);
  }
}

@media (min-width: 1216px) {
  .content--wide .content__block > h2 + .panel {
    margin-top: 48px;
  }
}

@media all and (min-width: 800px) {
  .content--wide .content__block--venue h2 {
    margin-bottom: 48px;
  }
}

@media (min-width: 800px) and (min-width: 560px) {
  .content--wide .content__block--venue h2 {
    margin-bottom: calc(2.4390243902vw + 34.3414634146px);
  }
}

@media (min-width: 800px) and (min-width: 1216px) {
  .content--wide .content__block--venue h2 {
    margin-bottom: 64px;
  }
}

@media all and (min-width: 800px) {
  .content--wide .content__block--venue img {
    width: calc(100% + 64px);
    margin-left: -64px;
    margin-top: -32px;
    margin-bottom: 32px;
    position: relative;
    z-index: 1;
  }
}

@media all and (max-width: 800px) {
  .content--wide .content__block--venue .prose {
    margin-bottom: 16px;
  }
}

@media (max-width: 800px) and (min-width: 560px) {
  .content--wide .content__block--venue .prose {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (max-width: 800px) and (min-width: 1216px) {
  .content--wide .content__block--venue .prose {
    margin-bottom: 32px;
  }
}

@media all and (max-width: 800px) {
  .content__block--image-pair img + img {
    margin-top: 16px;
  }
}

@media (max-width: 800px) and (min-width: 560px) {
  .content__block--image-pair img + img {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (max-width: 800px) and (min-width: 1216px) {
  .content__block--image-pair img + img {
    margin-top: 32px;
  }
}

.download {
  display: flex;
  text-decoration: none;
  background-color: var(--main-colour-tint, #f6f6f6);
}

.download__icon {
  transition: background-color 0.2s ease;
  flex: 0 0 auto;
  background-color: var(--main-colour-tint, #f6f6f6);
  padding: 16px;
}

.download__message {
  display: flex;
  width: 100%;
  align-items: center;
  padding: 16px;
}

.download:hover .download__icon {
  background-color: var(--accent-colour);
}

.emergency-header {
  text-align: center;
  position: -webkit-sticky;
  position: sticky;
  z-index: 100;
  padding: 1em 0;
  top: 0;
}

.emergency-modal {
  position: fixed;
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
  z-index: 200;
  padding: 20px;
  opacity: 0;
  visibility: hidden;
  transition: 500ms opacity, 500ms visibility;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.emergency-modal--show {
  opacity: 1;
  visibility: visible;
  transition-delay: 500ms;
}

.emergency-modal .slat {
  margin: 0 !important;
  padding: 0;
}

.emergency-modal__close {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  background: rgba(0, 0, 0, 0.7);
}

.emergency-modal__content {
  position: relative;
  z-index: 1;
  max-height: 100%;
  overflow-y: auto;
  max-width: 920px;
  width: 100%;
  margin: auto;
}

.emergency-modal__close-button {
  position: absolute;
  height: 2.5em;
  width: 2.5em;
  background: transparent;
  right: 0;
  top: 0;
}

.emergency-modal__close-button:before,
.emergency-modal__close-button:after {
  content: "";
  width: 1.5em;
  height: 2px;
  background: #212227;
  border-radius: 2px;
  position: absolute;
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
  left: 50%;
  top: 50%;
}

.emergency-modal__close-button:after {
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
          transform: translate(-50%, -50%) rotate(-45deg);
}

.event-card {
  text-align: left;
  text-decoration: none;
  display: flex;
  align-items: center;
  min-height: 322px;
  box-shadow: 0px 4px 32px rgba(0, 0, 0, 0.2);
  position: relative;
}

.event-card__img {
  background-size: cover;
  background-position: center center;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  opacity: 0.8;
}

.event-card__content {
  padding: 16px;
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 2;
}

@media (min-width: 560px) {
  .event-card__content {
    padding: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .event-card__content {
    padding: 32px;
  }
}

.event-card__title {
  color: currentColor;
  margin-bottom: 8px;
  font-size: 27.648px;
}

@media (min-width: 560px) {
  .event-card__title {
    font-size: calc(1.5634146341vw + 18.8928780488px);
  }
}

@media (min-width: 1216px) {
  .event-card__title {
    font-size: 37.904px;
  }
}

.event-card__when {
  margin-bottom: 8px;
}

.event-card__when,
.event-card__status {
  font-weight: 800;
  font-size: 23.04px;
  line-height: 1.1;
}

@media (min-width: 560px) {
  .event-card__when,
  .event-card__status {
    font-size: calc(0.8219512195vw + 18.4370731707px);
  }
}

@media (min-width: 1216px) {
  .event-card__when,
  .event-card__status {
    font-size: 28.432px;
  }
}

.event-card__ribbon {
  font-size: 16px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #fff;
  font-weight: 800;
  position: absolute;
  width: 180px;
  height: 100%;
  top: 0;
  right: 0;
  bottom: 0;
  background-position: 0 -180px;
  background-size: auto 600px;
  z-index: 1;
}

.event-card__label {
  text-align: center;
  margin-top: 8px;
  display: block;
  width: 100%;
}

.event-card--meetup,
.event-card--meetup:hover,
.event-card--meetup:active,
.event-card--meetup:visited {
  background-color: #fff;
  color: #212227;
}

.event-card--meetup .event-card__when {
  color: #00c2aa;
}

.event-card--meetup .event-card__ribbon {
  background-image: url("/assets/img/bg-ribbon-meetup-alt.svg");
}

.event-card--retreat,
.event-card--retreat:hover,
.event-card--retreat:active,
.event-card--retreat:visited {
  background-color: #000;
  color: #fff;
}

.event-card--retreat .event-card__when {
  color: #00c2aa;
}

.event-card--retreat .event-card__title,
.event-card--retreat .event-card__status {
  color: #fff;
}

.event-card--retreat .event-card__ribbon {
  background-image: url("/assets/img/bg-ribbon-retreat-alt.svg");
}

.event-card--conference,
.event-card--conference:hover,
.event-card--conference:active,
.event-card--conference:visited {
  background-color: #212227;
  color: #fff;
}

.event-card--conference .event-card__when {
  color: #d52bb5;
}

.event-card--conference .event-card__ribbon {
  background-image: url("/assets/img/bg-ribbon-conference-alt.svg");
}

.event-card--conference .event-card__img {
  background-blend-mode: overlay;
}

.event-card--coaching,
.event-card--coaching:hover,
.event-card--coaching:active,
.event-card--coaching:visited {
  background-color: #fff;
  color: #212227;
}

.event-card--coaching .event-card__when {
  color: #00198F;
}

.event-card--coaching .event-card__title,
.event-card--coaching .event-card__status {
  color: #212227;
}

.event-card--coaching .event-card__ribbon {
  background-image: url("/assets/img/bg-ribbon-coaching-alt.svg");
}

@media all and (min-width: 560px) {
  .card-set--single .event-card {
    align-items: stretch;
  }

  .card-set--single .event-card__ribbon {
    flex: 0 0 180px;
    display: flex;
    align-items: center;
    text-align: center;
    letter-spacing: 0.05em;
    background-repeat: no-repeat;
    background-position: top left;
    background-size: 100% auto;
    position: static;
    width: auto;
    height: auto;
  }

  .card-set--single .event-card__label {
    margin-top: 0;
  }

  .card-set--single .event-card--meetup .event-card__ribbon {
    background-image: url("/assets/img/bg-ribbon-meetup.svg");
  }

  .card-set--single .event-card--retreat .event-card__ribbon {
    background-image: url("/assets/img/bg-ribbon-retreat.svg");
  }

  .card-set--single .event-card--conference .event-card__ribbon {
    background-image: url("/assets/img/bg-ribbon-conference.svg");
  }

  .card-set--single .event-card--coaching .event-card__ribbon {
    background-image: url("/assets/img/bg-ribbon-coaching.svg");
  }

  .card-set--single .event-card__title {
    font-size: 39.68px;
  }
}

@media (min-width: 560px) and (min-width: 560px) {
  .card-set--single .event-card__title {
    font-size: calc(4.2170731707vw + 16.0643902439px);
  }
}

@media (min-width: 560px) and (min-width: 1216px) {
  .card-set--single .event-card__title {
    font-size: 67.344px;
  }
}

@media all and (min-width: 560px) {
  .card-set--single .event-card--coaching .event-card__title {
    font-size: 27.648px;
  }
}

@media (min-width: 560px) and (min-width: 560px) {
  .card-set--single .event-card--coaching .event-card__title {
    font-size: calc(3.5597560976vw + 7.7133658537px);
  }
}

@media (min-width: 560px) and (min-width: 1216px) {
  .card-set--single .event-card--coaching .event-card__title {
    font-size: 51px;
  }
}

@media all and (min-width: 560px) {
  .card-set--single .event-card--coaching .event-card__when {
    font-size: 27.648px;
  }
}

@media (min-width: 560px) and (min-width: 560px) {
  .card-set--single .event-card--coaching .event-card__when {
    font-size: calc(2.1573170732vw + 15.5670243902px);
  }
}

@media (min-width: 560px) and (min-width: 1216px) {
  .card-set--single .event-card--coaching .event-card__when {
    font-size: 41.8px;
  }
}

@media all and (min-width: 560px) {
  .card-set--single .event-card__when {
    font-size: 33.184px;
  }
}

@media (min-width: 560px) and (min-width: 560px) {
  .card-set--single .event-card__when {
    font-size: calc(2.6414634146vw + 18.391804878px);
  }
}

@media (min-width: 560px) and (min-width: 1216px) {
  .card-set--single .event-card__when {
    font-size: 50.512px;
  }
}

@media all and (max-width: 560px) {
  .card-set--double .event-card + .event-card {
    margin-top: 0;
  }
}

@media all and (min-width: 1024px) {
  .card-set--double .event-card {
    align-items: stretch;
  }

  .card-set--double .event-card__ribbon {
    flex: 0 0 180px;
    display: flex;
    align-items: center;
    text-align: center;
    letter-spacing: 0.05em;
    background-repeat: no-repeat;
    background-position: top left;
    background-size: 100% auto;
    position: static;
    width: auto;
    height: auto;
  }

  .card-set--double .event-card__label {
    margin-top: 0;
  }

  .card-set--double .event-card--meetup .event-card__ribbon {
    background-image: url("/assets/img/bg-ribbon-meetup.svg");
  }

  .card-set--double .event-card--retreat .event-card__ribbon {
    background-image: url("/assets/img/bg-ribbon-retreat.svg");
  }

  .card-set--double .event-card--conference .event-card__ribbon {
    background-image: url("/assets/img/bg-ribbon-conference.svg");
  }

  .card-set--double .event-card--coaching .event-card__ribbon {
    background-image: url("/assets/img/bg-ribbon-coaching.svg");
  }
}

@media all and (min-width: 560px) and (max-width: 800px) {
  .card-set--triple :nth-child(3) .event-card {
    align-items: stretch;
  }

  .card-set--triple :nth-child(3) .event-card__ribbon {
    flex: 0 0 180px;
    display: flex;
    align-items: center;
    text-align: center;
    letter-spacing: 0.05em;
    background-repeat: no-repeat;
    background-position: top left;
    background-size: 100% auto;
    position: static;
    width: auto;
    height: auto;
  }

  .card-set--triple :nth-child(3) .event-card__label {
    margin-top: 0;
  }

  .card-set--triple :nth-child(3) .event-card--meetup .event-card__ribbon {
    background-image: url("/assets/img/bg-ribbon-meetup.svg");
  }

  .card-set--triple :nth-child(3) .event-card--retreat .event-card__ribbon {
    background-image: url("/assets/img/bg-ribbon-retreat.svg");
  }

  .card-set--triple :nth-child(3) .event-card--conference .event-card__ribbon {
    background-image: url("/assets/img/bg-ribbon-conference.svg");
  }

  .card-set--triple :nth-child(3) .event-card--coaching .event-card__ribbon {
    background-image: url("/assets/img/bg-ribbon-coaching.svg");
  }

  .card-set--triple :nth-child(3) .event-card__title {
    font-size: 39.68px;
  }
}

@media (min-width: 560px) and (max-width: 800px) and (min-width: 560px) {
  .card-set--triple :nth-child(3) .event-card__title {
    font-size: calc(4.2170731707vw + 16.0643902439px);
  }
}

@media (min-width: 560px) and (max-width: 800px) and (min-width: 1216px) {
  .card-set--triple :nth-child(3) .event-card__title {
    font-size: 67.344px;
  }
}

@media all and (min-width: 560px) and (max-width: 800px) {
  .card-set--triple :nth-child(3) .event-card--coaching .event-card__title {
    font-size: 27.648px;
  }
}

@media (min-width: 560px) and (max-width: 800px) and (min-width: 560px) {
  .card-set--triple :nth-child(3) .event-card--coaching .event-card__title {
    font-size: calc(3.5597560976vw + 7.7133658537px);
  }
}

@media (min-width: 560px) and (max-width: 800px) and (min-width: 1216px) {
  .card-set--triple :nth-child(3) .event-card--coaching .event-card__title {
    font-size: 51px;
  }
}

@media all and (min-width: 560px) and (max-width: 800px) {
  .card-set--triple :nth-child(3) .event-card--coaching .event-card__when {
    font-size: 27.648px;
  }
}

@media (min-width: 560px) and (max-width: 800px) and (min-width: 560px) {
  .card-set--triple :nth-child(3) .event-card--coaching .event-card__when {
    font-size: calc(2.1573170732vw + 15.5670243902px);
  }
}

@media (min-width: 560px) and (max-width: 800px) and (min-width: 1216px) {
  .card-set--triple :nth-child(3) .event-card--coaching .event-card__when {
    font-size: 41.8px;
  }
}

@media all and (min-width: 560px) and (max-width: 800px) {
  .card-set--triple :nth-child(3) .event-card__when {
    font-size: 33.184px;
  }
}

@media (min-width: 560px) and (max-width: 800px) and (min-width: 560px) {
  .card-set--triple :nth-child(3) .event-card__when {
    font-size: calc(2.6414634146vw + 18.391804878px);
  }
}

@media (min-width: 560px) and (max-width: 800px) and (min-width: 1216px) {
  .card-set--triple :nth-child(3) .event-card__when {
    font-size: 50.512px;
  }
}

.field__label {
  display: block;
  margin-bottom: 8px;
}

.form__fields .field + *,
.field + .prose + * {
  margin-top: 16px;
}

@media (min-width: 560px) {
  .form__fields .field + *,
  .field + .prose + * {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .form__fields .field + *,
  .field + .prose + * {
    margin-top: 32px;
  }
}

.field__input {
  width: 100%;
}

.field--checkbox,
.field--radio {
  display: flex;
  flex-wrap: wrap;
}

.field--checkbox .field__label,
.field--radio .field__label {
  width: calc(100% - 30px);
}

.field--checkbox .field__input,
.field--radio .field__input {
  width: auto;
  position: relative;
  top: 7px;
  margin-right: 16px;
}

.field--checkbox .field__error,
.field--radio .field__error {
  display: block;
  padding-left: 30px;
}

.field__error {
  font-weight: 700;
  color: #d52bb5;
}

.form {
  max-width: 600px;
  margin: 0 auto;
}

.form__notification {
  margin-bottom: 16px;
}

@media (min-width: 560px) {
  .form__notification {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .form__notification {
    margin-bottom: 32px;
  }
}

.form__footer {
  margin-top: 32px;
  text-align: center;
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

@media (min-width: 560px) {
  .form__footer {
    margin-top: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .form__footer {
    margin-top: 64px;
  }
}

.form__footer .g-recaptcha {
  margin-bottom: 1.5rem;
}

.form .prose {
  border-bottom: 1px solid #e9e9e9;
  padding-bottom: 16px;
}

@media (min-width: 560px) {
  .form .prose {
    padding-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .form .prose {
    padding-bottom: 32px;
  }
}

.form .field + .prose {
  border-top: 1px solid #e9e9e9;
  padding-top: 16px;
}

@media (min-width: 560px) {
  .form .field + .prose {
    padding-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .form .field + .prose {
    padding-top: 32px;
  }
}

.image-group--linear .imgset + .imgset {
  margin-top: 16px;
}

@media (min-width: 560px) {
  .image-group--linear .imgset + .imgset {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .image-group--linear .imgset + .imgset {
    margin-top: 32px;
  }
}

.in-the-area {
  display: flex;
  flex-wrap: wrap;
  margin-right: -8px;
  margin-left: -8px;
  margin-top: -8px;
}

@media (min-width: 560px) {
  .in-the-area {
    margin-right: calc(-1.2195121951vw - 1.1707317073px);
  }
}

@media (min-width: 1216px) {
  .in-the-area {
    margin-right: -16px;
  }
}

@media (min-width: 560px) {
  .in-the-area {
    margin-left: calc(-1.2195121951vw - 1.1707317073px);
  }
}

@media (min-width: 1216px) {
  .in-the-area {
    margin-left: -16px;
  }
}

@media (min-width: 560px) {
  .in-the-area {
    margin-top: calc(-1.2195121951vw - 1.1707317073px);
  }
}

@media (min-width: 1216px) {
  .in-the-area {
    margin-top: -16px;
  }
}

.in-the-area__venue {
  padding: 8px;
  width: 100%;
}

@media (min-width: 560px) {
  .in-the-area__venue {
    padding: calc(1.2195121951vw + 1.1707317073px);
  }
}

@media (min-width: 1216px) {
  .in-the-area__venue {
    padding: 16px;
  }
}

.in-the-area__info {
  width: 100%;
  font-size: 18px;
  background-color: var(--main-colour-tint, #f6f6f6);
  padding: 16px;
  border-left: 4px solid var(--main-colour);
}

@media (min-width: 560px) {
  .in-the-area__info {
    padding: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .in-the-area__info {
    padding: 32px;
  }
}

.in-the-area__name {
  margin-bottom: 10px;
}

.in-the-area__description {
  font-size: 18px;
}

.in-the-area__address {
  margin-top: 8px;
  font-style: italic;
}

.in-the-area__website {
  display: block;
  margin-top: 8px;
}

@media all and (min-width: 560px) {
  .in-the-area__venue {
    width: 50%;
  }
}

@media all and (min-width: 1024px) {
  .in-the-area__venue {
    width: 33%;
  }
}

.input-group .field {
  width: 100%;
  display: flex;
  margin-bottom: 16px;
}

.input-group .input {
  flex: 1;
  width: 100%;
}

.input-group .button {
  flex: 1 0 auto;
}

.input-group--unlabelled .label {
  display: none;
}

@media all and (min-width: 560px) {
  .input-group {
    display: flex;
    align-items: stretch;
  }

  .input-group .field {
    margin-bottom: 0;
  }
}

.map {
  position: relative;
  padding-bottom: 100%;
  height: 0;
  margin: 0;
}

.map__content {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.masterclass {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: 1rem;
}

.masterclass__sold-out {
  font-size: 16px;
  color: #666;
  display: block;
}

.masterclass__time {
  color: #999;
  display: block;
  margin-bottom: 1rem;
  font-size: 16px;
  position: relative;
}

.masterclass__time .icon {
  width: 1em;
  height: 1em;
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
}

.masterclass__images img {
  width: 100%;
}

.masterclass__images > :first-child:nth-last-child(2),
.masterclass__images > :first-child:nth-last-child(2) ~ * {
  width: 55%;
}

.masterclass__images > :first-child:nth-last-child(2) ~ * {
  margin: -50% 0 0 45%;
}

.masterclass__image {
  margin: 0;
}

.masterclass__speaker {
  font-size: 16px;
  margin-bottom: 0.25em;
  margin-top: 0.25em;
}

.masterclass__speaker a {
  font-weight: 700;
  color: inherit;
}

.masterclass--major {
  margin-bottom: 40px !important;
}

@media (min-width: 560px) {
  .masterclass--major {
    margin-bottom: calc(7.012195122vw + 0.7317073171px) !important;
  }
}

@media (min-width: 1216px) {
  .masterclass--major {
    margin-bottom: 86px !important;
  }
}

.masterclass--major .masterclass__content {
  padding-bottom: 1rem;
}

@media (min-width: 40em) {
  .masterclass--major {
    grid-template-columns: 28% 1fr;
    grid-gap: 2rem;
  }
}

.masterclass--minor .masterclass__images {
  max-width: 150px;
}

.masterclass--minor .masterclass__time {
  color: #666;
}

.masterclass--minor + .masterclass--minor {
  margin-top: 1.5rem;
}

@media (min-width: 40em) {
  .masterclass--minor {
    border-bottom: 1px solid rgba(33, 34, 39, 0.2);
    grid-template-columns: 15% 1fr;
    grid-gap: 1rem;
  }
}

.masterclasses__group {
  border-top: 1px solid rgba(35, 66, 61, 0.2);
}

.masterclasses__date {
  color: var(--accent-colour);
  display: block;
}

.masterclasses__day {
  margin: 0.5rem 0;
  margin-bottom: 30px !important;
}

@media (min-width: 560px) {
  .masterclasses__day {
    margin-bottom: calc(3.8109756098vw + 8.6585365854px) !important;
  }
}

@media (min-width: 1216px) {
  .masterclasses__day {
    margin-bottom: 55px !important;
  }
}

.mini-profile__img {
  width: 100%;
  margin-bottom: 16px;
}

@media (min-width: 560px) {
  .mini-profile__img {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .mini-profile__img {
    margin-bottom: 32px;
  }
}

.mini-profile__name {
  margin-bottom: 4px;
}

.mini-profile .social {
  margin-top: 16px;
}

.mini-venue .map {
  margin-bottom: 16px;
}

@media (min-width: 560px) {
  .mini-venue .map {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .mini-venue .map {
    margin-bottom: 32px;
  }
}

.mini-venue__name {
  margin-bottom: 4px;
}

.mini-venue__address {
  margin-top: 16px;
}

.mini-venue__website {
  margin-top: 16px;
  text-decoration: none;
  display: flex;
  align-items: center;
}

.mini-venue__website span {
  text-decoration: underline;
}

.mini-venue__website .icon {
  width: 32px;
  height: 32px;
  margin-right: 4px;
}

.mini-venue__tbc {
  position: relative;
}

.mini-venue__tbc-map {
  width: 100%;
  opacity: 0.3;
}

.mini-venue__tbc-label {
  font-size: 21px;
  position: absolute;
  text-transform: uppercase;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.no-events {
  background-color: #f6f6f6;
  padding-top: 32px;
  padding-bottom: 32px;
  text-align: left;
  color: #212227;
  background: #fff;
}

@media (min-width: 560px) {
  .no-events {
    padding-top: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .no-events {
    padding-top: 64px;
  }
}

@media (min-width: 560px) {
  .no-events {
    padding-bottom: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .no-events {
    padding-bottom: 64px;
  }
}

.no-events__title {
  text-align: center;
  margin-bottom: 16px;
}

@media (min-width: 560px) {
  .no-events__title {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .no-events__title {
    margin-bottom: 32px;
  }
}

.notification--error {
  font-weight: 700;
  color: #d52bb5;
}

.has-js .online-schedule-day {
  display: none;
}

.has-js .online-schedule-day.is-active {
  display: block;
}

.online-schedule-day__overview .prose {
  margin-top: 10.6666666667px;
}

@media (min-width: 560px) {
  .online-schedule-day__overview .prose {
    margin-top: calc(1.6260162602vw + 1.5609756098px);
  }
}

@media (min-width: 1216px) {
  .online-schedule-day__overview .prose {
    margin-top: 21.3333333333px;
  }
}

.online-schedule-day__schedule {
  margin-top: 16px;
}

@media (min-width: 560px) {
  .online-schedule-day__schedule {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .online-schedule-day__schedule {
    margin-top: 32px;
  }
}

.online-schedule-day__item {
  padding: 16px;
}

@media (min-width: 560px) {
  .online-schedule-day__item {
    padding: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .online-schedule-day__item {
    padding: 32px;
  }
}

.online-schedule-day__title {
  margin-bottom: 16px;
}

.online-schedule-day__item--registration,
.online-schedule-day__item--break {
  padding-top: 8px;
  padding-bottom: 12px;
  background-color: var(--main-colour-tint, #f6f6f6);
}

@media (min-width: 560px) {
  .online-schedule-day__item--registration,
  .online-schedule-day__item--break {
    padding-top: calc(0.6097560976vw + 4.5853658537px);
  }
}

@media (min-width: 1216px) {
  .online-schedule-day__item--registration,
  .online-schedule-day__item--break {
    padding-top: 12px;
  }
}

@media (min-width: 560px) {
  .online-schedule-day__item--registration,
  .online-schedule-day__item--break {
    padding-bottom: calc(0.6097560976vw + 8.5853658537px);
  }
}

@media (min-width: 1216px) {
  .online-schedule-day__item--registration,
  .online-schedule-day__item--break {
    padding-bottom: 16px;
  }
}

.online-schedule-day__item--registration + .online-schedule-day__item--registration,
.online-schedule-day__item--registration + .online-schedule-day__item--break,
.online-schedule-day__item--registration + .online-schedule-day__item--evening,
.online-schedule-day__item--registration + .online-schedule-day__item--morning,
.online-schedule-day__item--break + .online-schedule-day__item--registration,
.online-schedule-day__item--break + .online-schedule-day__item--break,
.online-schedule-day__item--break + .online-schedule-day__item--evening,
.online-schedule-day__item--break + .online-schedule-day__item--morning,
.online-schedule-day__item--evening + .online-schedule-day__item--registration,
.online-schedule-day__item--evening + .online-schedule-day__item--break,
.online-schedule-day__item--evening + .online-schedule-day__item--evening,
.online-schedule-day__item--evening + .online-schedule-day__item--morning,
.online-schedule-day__item--morning + .online-schedule-day__item--registration,
.online-schedule-day__item--morning + .online-schedule-day__item--break,
.online-schedule-day__item--morning + .online-schedule-day__item--evening,
.online-schedule-day__item--morning + .online-schedule-day__item--morning {
  margin-top: 16px;
}

@media (min-width: 560px) {
  .online-schedule-day__item--registration + .online-schedule-day__item--registration,
  .online-schedule-day__item--registration + .online-schedule-day__item--break,
  .online-schedule-day__item--registration + .online-schedule-day__item--evening,
  .online-schedule-day__item--registration + .online-schedule-day__item--morning,
  .online-schedule-day__item--break + .online-schedule-day__item--registration,
  .online-schedule-day__item--break + .online-schedule-day__item--break,
  .online-schedule-day__item--break + .online-schedule-day__item--evening,
  .online-schedule-day__item--break + .online-schedule-day__item--morning,
  .online-schedule-day__item--evening + .online-schedule-day__item--registration,
  .online-schedule-day__item--evening + .online-schedule-day__item--break,
  .online-schedule-day__item--evening + .online-schedule-day__item--evening,
  .online-schedule-day__item--evening + .online-schedule-day__item--morning,
  .online-schedule-day__item--morning + .online-schedule-day__item--registration,
  .online-schedule-day__item--morning + .online-schedule-day__item--break,
  .online-schedule-day__item--morning + .online-schedule-day__item--evening,
  .online-schedule-day__item--morning + .online-schedule-day__item--morning {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .online-schedule-day__item--registration + .online-schedule-day__item--registration,
  .online-schedule-day__item--registration + .online-schedule-day__item--break,
  .online-schedule-day__item--registration + .online-schedule-day__item--evening,
  .online-schedule-day__item--registration + .online-schedule-day__item--morning,
  .online-schedule-day__item--break + .online-schedule-day__item--registration,
  .online-schedule-day__item--break + .online-schedule-day__item--break,
  .online-schedule-day__item--break + .online-schedule-day__item--evening,
  .online-schedule-day__item--break + .online-schedule-day__item--morning,
  .online-schedule-day__item--evening + .online-schedule-day__item--registration,
  .online-schedule-day__item--evening + .online-schedule-day__item--break,
  .online-schedule-day__item--evening + .online-schedule-day__item--evening,
  .online-schedule-day__item--evening + .online-schedule-day__item--morning,
  .online-schedule-day__item--morning + .online-schedule-day__item--registration,
  .online-schedule-day__item--morning + .online-schedule-day__item--break,
  .online-schedule-day__item--morning + .online-schedule-day__item--evening,
  .online-schedule-day__item--morning + .online-schedule-day__item--morning {
    margin-top: 32px;
  }
}

.online-schedule-day__item--registration .online-schedule-day__item-title,
.online-schedule-day__item--break .online-schedule-day__item-title {
  font-size: 21px;
  line-height: 1.1;
}

.online-schedule-day__item--talk + .online-schedule-day__item--talk {
  border-top: 1px solid rgba(33, 34, 39, 0.2);
}

.online-schedule-day__item--morning,
.online-schedule-day__item--evening {
  border: 1px solid rgba(33, 34, 39, 0.2);
}

.online-schedule-day__item-meta {
  flex: none;
  color: var(--main-colour);
}

.online-schedule-day__time {
  color: var(--main-colour);
  font-weight: 400;
  display: flex;
  margin-bottom: 4px;
  align-items: center;
  justify-content: flex-start;
  position: relative;
  cursor: pointer;
}

.online-schedule-day__time .icon {
  margin-right: 0.375rem;
  margin-left: -0.125rem;
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  width: 1em;
  height: 1em;
  color: #999;
}

.online-schedule-day__venue,
.online-schedule-day__venue:hover,
.online-schedule-day__venue:active,
.online-schedule-day__venue:visited {
  color: #999;
  text-decoration: none;
  display: flex;
}

.online-schedule-day__venue svg,
.online-schedule-day__venue:hover svg,
.online-schedule-day__venue:active svg,
.online-schedule-day__venue:visited svg {
  margin-top: -1px;
  margin-right: 4px;
}

.online-schedule-day__room {
  display: block;
}

.online-schedule-day__item-title.is-tbc {
  font-size: 19.2px;
}

@media (min-width: 560px) {
  .online-schedule-day__item-title.is-tbc {
    font-size: calc(0.3243902439vw + 17.3834146341px);
  }
}

@media (min-width: 1216px) {
  .online-schedule-day__item-title.is-tbc {
    font-size: 21.328px;
  }
}

.online-schedule-day__item-title a {
  text-decoration: none;
  color: currentColor;
}

.online-schedule-day__speakers {
  margin-top: 8px;
  font-size: 16px;
}

.online-schedule-day__speaker-name {
  display: inline-block;
  padding: 0px 4px;
  background-color: var(--accent-colour-knockback);
  color: var(--main-colour);
  font-weight: 700;
}

.online-schedule-day__speaker-name:hover,
.online-schedule-day__speaker-name:visited {
  color: var(--main-colour);
}

.online-schedule-day__about {
  font-size: 16px;
  margin-top: 8px;
}

@media (min-width: 560px) {
  .online-schedule-day__about {
    font-size: calc(0.3048780488vw + 14.2926829268px);
  }
}

@media (min-width: 1216px) {
  .online-schedule-day__about {
    font-size: 18px;
  }
}

.online-schedule-day__sponsors {
  margin-top: 16px;
  font-size: 16px;
}

.online-schedule-day__sponsors img {
  display: inline-block;
  margin-left: 2px;
}

@media all and (min-width: 800px) {
  .online-schedule-day__item {
    display: flex;
    align-items: flex-start;
  }

  .online-schedule-day__time {
    margin-bottom: 0;
  }

  .online-schedule-day__item-meta {
    width: 170px;
    text-align: right;
    flex: none;
    margin-right: 16px;
  }
}

@media (min-width: 800px) and (min-width: 560px) {
  .online-schedule-day__item-meta {
    margin-right: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 800px) and (min-width: 1216px) {
  .online-schedule-day__item-meta {
    margin-right: 32px;
  }
}

@media all and (min-width: 800px) {
  .online-schedule-day__item--registration,
  .online-schedule-day__item--break {
    padding-bottom: 8px;
  }
}

@media (min-width: 800px) and (min-width: 560px) {
  .online-schedule-day__item--registration,
  .online-schedule-day__item--break {
    padding-bottom: calc(0.6097560976vw + 4.5853658537px);
  }
}

@media (min-width: 800px) and (min-width: 1216px) {
  .online-schedule-day__item--registration,
  .online-schedule-day__item--break {
    padding-bottom: 12px;
  }
}

@media all and (min-width: 800px) {
  .online-schedule-day__item--registration .online-schedule-day__item-title,
  .online-schedule-day__item--break .online-schedule-day__item-title {
    margin-top: 0.2em;
  }
}

.inline-modal {
  position: absolute;
  left: -0.675rem;
  bottom: 100%;
  background: #f6f6f6;
  padding: 0.25rem 0.5rem;
  -webkit-filter: drop-shadow(0 0 4px rgba(0, 0, 0, 0.2));
          filter: drop-shadow(0 0 4px rgba(0, 0, 0, 0.2));
  white-space: nowrap;
  font-size: 0.75rem;
  font-weight: 700;
  -webkit-transform: translateY(-0.75rem);
          transform: translateY(-0.75rem);
  opacity: 0;
  visibility: hidden;
  transition: 300ms opacity, 300ms visibility;
  color: var(--main-colour);
}

.inline-modal.is-open {
  opacity: 1;
  visibility: visible;
}

.inline-modal:after {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 10px 10px 0 10px;
  border-color: #f6f6f6 transparent transparent transparent;
  position: absolute;
  left: 0.5rem;
  top: 100%;
  content: "";
}

.online-tickets__panel {
  background: #f6f6f6;
  padding: 16px;
}

@media (min-width: 560px) {
  .online-tickets__panel {
    padding: calc(4.8780487805vw - 11.3170731707px);
  }
}

@media (min-width: 1216px) {
  .online-tickets__panel {
    padding: 48px;
  }
}

.online-tickets__panel:not(:first-child) {
  margin-top: 48px;
}

.online-tickets__subtitle {
  margin-top: 0.5rem;
  font-weight: 400;
  color: var(--accent-colour);
}

.online-tickets__date {
  margin-top: 0.25rem;
  font-weight: 700;
  opacity: 0.8;
}

.online-tickets .prose {
  margin-top: 1rem;
}

.online-tickets__band--sold-out {
  opacity: 0.4;
}

.online-tickets__band--sold-out strong,
.online-tickets__band--sold-out span {
  text-decoration: line-through;
}

.online-tickets__prices {
  margin: 1.5rem 0 0.5rem;
  display: flex;
  flex-wrap: wrap;
}

.online-tickets__prices li {
  display: flex;
  flex-direction: column;
  line-height: 1.3;
  margin-bottom: 1rem;
  margin-right: 16px;
}

@media (min-width: 560px) {
  .online-tickets__prices li {
    margin-right: calc(4.8780487805vw - 11.3170731707px);
  }
}

@media (min-width: 1216px) {
  .online-tickets__prices li {
    margin-right: 48px;
  }
}

.online-tickets__prices strong {
  font-size: 1.25rem;
  font-weight: 800;
}

.online-tickets__prices span {
  font-size: 0.875rem;
  font-weight: 700;
}

.online-tickets__prices small {
  font-size: 0.75rem;
  opacity: 0.8;
  margin-top: 0.125rem;
}

.past-events__event,
.past-events__event:visited,
.past-events__event:hover,
.past-events__event:active {
  background-color: #fff;
  padding: 16px;
  position: relative;
  min-height: 110px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-decoration: none;
  color: #212227;
}

@media (min-width: 560px) {
  .past-events__event,
  .past-events__event:visited,
  .past-events__event:hover,
  .past-events__event:active {
    padding: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .past-events__event,
  .past-events__event:visited,
  .past-events__event:hover,
  .past-events__event:active {
    padding: 32px;
  }
}

.past-events__event + .past-events__event {
  margin-top: 16px;
}

@media (min-width: 560px) {
  .past-events__event + .past-events__event {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .past-events__event + .past-events__event {
    margin-top: 32px;
  }
}

.past-events__when {
  color: rgba(153, 153, 153, 0.5);
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 16px;
}

.past-events__title {
  max-width: calc(100% - 150px + 16px);
}

.past-events__ribbon {
  font-size: 14px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #fff;
  font-weight: 800;
  position: absolute;
  width: 150px;
  height: 100%;
  top: 0;
  right: 0;
  bottom: 0;
  background-position: 0 -180px;
  background-size: auto 480px;
  z-index: 1;
}

.past-events__label {
  text-align: center;
  margin-top: 8px;
  display: block;
  width: 100%;
}

.past-events__event--meetup .past-events__ribbon {
  background-image: url("/assets/img/bg-ribbon-meetup-alt.svg");
}

.past-events__event--retreat .past-events__ribbon {
  background-image: url("/assets/img/bg-ribbon-retreat-alt.svg");
}

.past-events__event--conference .past-events__ribbon {
  background-image: url("/assets/img/bg-ribbon-conference-alt.svg");
}

.past-events__event--coaching .past-events__ribbon {
  background-image: url("/assets/img/bg-ribbon-coaching-alt.svg");
}

.past-speakers-list {
  display: flex;
  flex-wrap: wrap;
  margin-right: -8px;
  margin-left: -8px;
  margin-top: -8px;
}

@media (min-width: 560px) {
  .past-speakers-list {
    margin-right: calc(-1.2195121951vw - 1.1707317073px);
  }
}

@media (min-width: 1216px) {
  .past-speakers-list {
    margin-right: -16px;
  }
}

@media (min-width: 560px) {
  .past-speakers-list {
    margin-left: calc(-1.2195121951vw - 1.1707317073px);
  }
}

@media (min-width: 1216px) {
  .past-speakers-list {
    margin-left: -16px;
  }
}

@media (min-width: 560px) {
  .past-speakers-list {
    margin-top: calc(-1.2195121951vw - 1.1707317073px);
  }
}

@media (min-width: 1216px) {
  .past-speakers-list {
    margin-top: -16px;
  }
}

.past-speakers-list__speaker {
  flex: 0 0 33.3333333%;
  padding: 8px;
  text-decoration: none;
}

@media (min-width: 560px) {
  .past-speakers-list__speaker {
    padding: calc(1.2195121951vw + 1.1707317073px);
  }
}

@media (min-width: 1216px) {
  .past-speakers-list__speaker {
    padding: 16px;
  }
}

.past-speakers-list__image,
.past-speakers-list__image img {
  width: 100%;
}

.past-speakers-list__image {
  background-color: var(--main-colour);
  position: relative;
}

.past-speakers-list__image::after {
  content: "";
  height: 100%;
  left: 0;
  opacity: 0.333;
  position: absolute;
  top: 0;
  width: 100%;
}

.past-speakers-list__image img {
  -webkit-filter: grayscale;
          filter: grayscale;
}

.past-speakers-list__name {
  margin-top: 8px;
}

.past-speakers-list__role,
.past-speakers-list__event {
  color: #212227;
  display: block;
  line-height: 1.2;
  margin-top: 4px;
  font-size: 16px;
}

.past-speakers-list__event {
  margin-top: 0.5rem;
  font-weight: 700;
}

@media all and (min-width: 560px) {
  .past-speakers-list__speaker {
    flex: 0 0 25%;
  }
}

@media all and (min-width: 800px) {
  .past-speakers-list__speaker {
    /* flex: 0 0 20%; */
  }
}

@media all and (min-width: 1024px) {
  .past-speakers-list__speaker {
    flex: 0 0 20%;
  }
}

.promo-set__panel {
  background-color: var(--accent-colour);
  padding: 16px;
}

@media (min-width: 560px) {
  .promo-set__panel {
    padding: calc(4.8780487805vw - 11.3170731707px);
  }
}

@media (min-width: 1216px) {
  .promo-set__panel {
    padding: 48px;
  }
}

.promo-set .prose a {
  --link-colour: var(--main-colour);
}

.promo-set__image {
  background-color: var(--main-colour);
}

.promo-set__image img {
  mix-blend-mode: screen;
  width: 100%;
}

.promo-set__title {
  margin-bottom: 16px;
}

.promo-set__subtitle {
  font-weight: 400;
  margin-top: -16px;
  margin-bottom: 16px;
  font-size: 1em;
  color: #212227;
  padding-top: 0.375em;
}

.promo-set__promo + .promo-set__promo {
  margin-top: 16px;
}

@media (min-width: 560px) {
  .promo-set__promo + .promo-set__promo {
    margin-top: calc(4.8780487805vw - 11.3170731707px);
  }
}

@media (min-width: 1216px) {
  .promo-set__promo + .promo-set__promo {
    margin-top: 48px;
  }
}

@media all and (min-width: 800px) {
  .promo-set__promo {
    display: flex;
    align-items: flex-start;
  }

  .promo-set__promo:nth-child(even) {
    flex-direction: row-reverse;
  }

  .promo-set__panel {
    width: 500px;
    z-index: 10;
    margin-top: 32px;
  }
}

@media (min-width: 800px) and (min-width: 560px) {
  .promo-set__panel {
    margin-top: calc(2.4390243902vw + 18.3414634146px);
  }
}

@media (min-width: 800px) and (min-width: 1216px) {
  .promo-set__panel {
    margin-top: 48px;
  }
}

@media all and (min-width: 800px) {
  .promo-set__image {
    width: 65%;
  }
}

@media all and (min-width: 800px) {
  .promo-set__promo:nth-child(even) .promo-set__image {
    margin-left: -32px;
  }
}

@media (min-width: 800px) and (min-width: 560px) {
  .promo-set__promo:nth-child(even) .promo-set__image {
    margin-left: calc(-2.4390243902vw - 18.3414634146px);
  }
}

@media (min-width: 800px) and (min-width: 1216px) {
  .promo-set__promo:nth-child(even) .promo-set__image {
    margin-left: -48px;
  }
}

@media all and (min-width: 800px) {
  .promo-set__promo:nth-child(odd) .promo-set__image {
    margin-right: -32px;
  }
}

@media (min-width: 800px) and (min-width: 560px) {
  .promo-set__promo:nth-child(odd) .promo-set__image {
    margin-right: calc(-2.4390243902vw - 18.3414634146px);
  }
}

@media (min-width: 800px) and (min-width: 1216px) {
  .promo-set__promo:nth-child(odd) .promo-set__image {
    margin-right: -48px;
  }
}

.has-js .schedule-day {
  display: none;
}

.has-js .schedule-day.is-active {
  display: block;
}

.schedule-day__overview .prose {
  margin-top: 10.6666666667px;
}

@media (min-width: 560px) {
  .schedule-day__overview .prose {
    margin-top: calc(1.6260162602vw + 1.5609756098px);
  }
}

@media (min-width: 1216px) {
  .schedule-day__overview .prose {
    margin-top: 21.3333333333px;
  }
}

.schedule-day__schedule {
  margin-top: 16px;
}

@media (min-width: 560px) {
  .schedule-day__schedule {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .schedule-day__schedule {
    margin-top: 32px;
  }
}

.schedule-day__item {
  padding: 16px;
}

@media (min-width: 560px) {
  .schedule-day__item {
    padding: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .schedule-day__item {
    padding: 32px;
  }
}

.schedule-day__title {
  margin-bottom: 16px;
}

.schedule-day__item--registration,
.schedule-day__item--break {
  padding-top: 8px;
  padding-bottom: 12px;
  background-color: var(--main-colour-tint, #f6f6f6);
}

@media (min-width: 560px) {
  .schedule-day__item--registration,
  .schedule-day__item--break {
    padding-top: calc(0.6097560976vw + 4.5853658537px);
  }
}

@media (min-width: 1216px) {
  .schedule-day__item--registration,
  .schedule-day__item--break {
    padding-top: 12px;
  }
}

@media (min-width: 560px) {
  .schedule-day__item--registration,
  .schedule-day__item--break {
    padding-bottom: calc(0.6097560976vw + 8.5853658537px);
  }
}

@media (min-width: 1216px) {
  .schedule-day__item--registration,
  .schedule-day__item--break {
    padding-bottom: 16px;
  }
}

.schedule-day__item--registration + .schedule-day__item--registration,
.schedule-day__item--registration + .schedule-day__item--break,
.schedule-day__item--registration + .schedule-day__item--evening,
.schedule-day__item--registration + .schedule-day__item--morning,
.schedule-day__item--break + .schedule-day__item--registration,
.schedule-day__item--break + .schedule-day__item--break,
.schedule-day__item--break + .schedule-day__item--evening,
.schedule-day__item--break + .schedule-day__item--morning,
.schedule-day__item--evening + .schedule-day__item--registration,
.schedule-day__item--evening + .schedule-day__item--break,
.schedule-day__item--evening + .schedule-day__item--evening,
.schedule-day__item--evening + .schedule-day__item--morning,
.schedule-day__item--morning + .schedule-day__item--registration,
.schedule-day__item--morning + .schedule-day__item--break,
.schedule-day__item--morning + .schedule-day__item--evening,
.schedule-day__item--morning + .schedule-day__item--morning {
  margin-top: 16px;
}

@media (min-width: 560px) {
  .schedule-day__item--registration + .schedule-day__item--registration,
  .schedule-day__item--registration + .schedule-day__item--break,
  .schedule-day__item--registration + .schedule-day__item--evening,
  .schedule-day__item--registration + .schedule-day__item--morning,
  .schedule-day__item--break + .schedule-day__item--registration,
  .schedule-day__item--break + .schedule-day__item--break,
  .schedule-day__item--break + .schedule-day__item--evening,
  .schedule-day__item--break + .schedule-day__item--morning,
  .schedule-day__item--evening + .schedule-day__item--registration,
  .schedule-day__item--evening + .schedule-day__item--break,
  .schedule-day__item--evening + .schedule-day__item--evening,
  .schedule-day__item--evening + .schedule-day__item--morning,
  .schedule-day__item--morning + .schedule-day__item--registration,
  .schedule-day__item--morning + .schedule-day__item--break,
  .schedule-day__item--morning + .schedule-day__item--evening,
  .schedule-day__item--morning + .schedule-day__item--morning {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .schedule-day__item--registration + .schedule-day__item--registration,
  .schedule-day__item--registration + .schedule-day__item--break,
  .schedule-day__item--registration + .schedule-day__item--evening,
  .schedule-day__item--registration + .schedule-day__item--morning,
  .schedule-day__item--break + .schedule-day__item--registration,
  .schedule-day__item--break + .schedule-day__item--break,
  .schedule-day__item--break + .schedule-day__item--evening,
  .schedule-day__item--break + .schedule-day__item--morning,
  .schedule-day__item--evening + .schedule-day__item--registration,
  .schedule-day__item--evening + .schedule-day__item--break,
  .schedule-day__item--evening + .schedule-day__item--evening,
  .schedule-day__item--evening + .schedule-day__item--morning,
  .schedule-day__item--morning + .schedule-day__item--registration,
  .schedule-day__item--morning + .schedule-day__item--break,
  .schedule-day__item--morning + .schedule-day__item--evening,
  .schedule-day__item--morning + .schedule-day__item--morning {
    margin-top: 32px;
  }
}

.schedule-day__item--registration .schedule-day__item-title,
.schedule-day__item--break .schedule-day__item-title {
  font-size: 21px;
  line-height: 1.1;
}

.schedule-day__item--talk + .schedule-day__item--talk {
  border-top: 1px solid rgba(33, 34, 39, 0.2);
}

.schedule-day__item--morning,
.schedule-day__item--evening {
  border: 1px solid rgba(33, 34, 39, 0.2);
}

.schedule-day__item-meta {
  flex: none;
  color: var(--main-colour);
}

.schedule-day__time {
  color: var(--main-colour);
  font-weight: 400;
  display: flex;
  margin-bottom: 4px;
  align-items: center;
  justify-content: flex-start;
  position: relative;
  cursor: pointer;
}

.schedule-day__time .icon {
  margin-right: 0.375rem;
  margin-left: -0.125rem;
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  width: 1em;
  height: 1em;
  color: #999;
}

.schedule-day__venue,
.schedule-day__venue:hover,
.schedule-day__venue:active,
.schedule-day__venue:visited {
  color: #999;
  text-decoration: none;
  display: flex;
}

.schedule-day__venue svg,
.schedule-day__venue:hover svg,
.schedule-day__venue:active svg,
.schedule-day__venue:visited svg {
  margin-top: -1px;
  margin-right: 4px;
}

.schedule-day__room {
  display: block;
}

.schedule-day__item-title.is-tbc {
  font-size: 19.2px;
}

@media (min-width: 560px) {
  .schedule-day__item-title.is-tbc {
    font-size: calc(0.3243902439vw + 17.3834146341px);
  }
}

@media (min-width: 1216px) {
  .schedule-day__item-title.is-tbc {
    font-size: 21.328px;
  }
}

.schedule-day__item-title a {
  text-decoration: none;
  color: currentColor;
}

.schedule-day__speakers {
  margin-top: 8px;
  font-size: 16px;
}

.schedule-day__speaker-name {
  display: inline-block;
  padding: 0px 4px;
  background-color: var(--accent-colour-knockback);
  color: var(--main-colour);
  font-weight: 700;
}

.schedule-day__speaker-name:hover,
.schedule-day__speaker-name:visited {
  color: var(--main-colour);
}

.schedule-day__about {
  font-size: 16px;
  margin-top: 8px;
}

@media (min-width: 560px) {
  .schedule-day__about {
    font-size: calc(0.3048780488vw + 14.2926829268px);
  }
}

@media (min-width: 1216px) {
  .schedule-day__about {
    font-size: 18px;
  }
}

.schedule-day__sponsors {
  margin-top: 16px;
  font-size: 16px;
}

.schedule-day__sponsors img {
  display: inline-block;
  margin-left: 2px;
}

@media all and (min-width: 800px) {
  .schedule-day__item {
    display: flex;
    align-items: flex-start;
  }

  .schedule-day__time {
    margin-bottom: 0;
  }

  .schedule-day__item-meta {
    width: 170px;
    text-align: right;
    flex: none;
    margin-right: 16px;
  }
}

@media (min-width: 800px) and (min-width: 560px) {
  .schedule-day__item-meta {
    margin-right: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 800px) and (min-width: 1216px) {
  .schedule-day__item-meta {
    margin-right: 32px;
  }
}

@media all and (min-width: 800px) {
  .schedule-day__item--registration,
  .schedule-day__item--break {
    padding-bottom: 8px;
  }
}

@media (min-width: 800px) and (min-width: 560px) {
  .schedule-day__item--registration,
  .schedule-day__item--break {
    padding-bottom: calc(0.6097560976vw + 4.5853658537px);
  }
}

@media (min-width: 800px) and (min-width: 1216px) {
  .schedule-day__item--registration,
  .schedule-day__item--break {
    padding-bottom: 12px;
  }
}

@media all and (min-width: 800px) {
  .schedule-day__item--registration .schedule-day__item-title,
  .schedule-day__item--break .schedule-day__item-title {
    margin-top: 0.2em;
  }
}

.inline-modal {
  position: absolute;
  left: -0.675rem;
  bottom: 100%;
  background: #f6f6f6;
  padding: 0.25rem 0.5rem;
  -webkit-filter: drop-shadow(0 0 4px rgba(0, 0, 0, 0.2));
          filter: drop-shadow(0 0 4px rgba(0, 0, 0, 0.2));
  white-space: nowrap;
  font-size: 0.75rem;
  font-weight: 700;
  -webkit-transform: translateY(-0.75rem);
          transform: translateY(-0.75rem);
  opacity: 0;
  visibility: hidden;
  transition: 300ms opacity, 300ms visibility;
  color: var(--main-colour);
}

.inline-modal.is-open {
  opacity: 1;
  visibility: visible;
}

.inline-modal:after {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 10px 10px 0 10px;
  border-color: #f6f6f6 transparent transparent transparent;
  position: absolute;
  left: 0.5rem;
  top: 100%;
  content: "";
}

.schedule-info {
  color: var(--main-colour);
}

.schedule-info__title {
  margin-bottom: 8px;
}

.schedule-jumper {
  font-size: 18px;
  --accent-colour: #FFF;
}

.schedule-jumper > * {
  margin: 0.125rem 0.375rem;
}

.schedule-jumper a {
  border-bottom: 1px solid;
}

@media (max-width: 450px) {
  .schedule-jumper {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
}

.schedule-switcher {
  margin-top: 16px;
  display: flex;
  justify-content: center;
}

@media (min-width: 560px) {
  .schedule-switcher {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .schedule-switcher {
    margin-top: 32px;
  }
}

.schedule-switcher__items {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(16ch, 1fr));
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  max-width: 100vw;
}

.schedule-switcher__item {
  position: relative;
}

.schedule-switcher__item .schedule-switcher__link,
.schedule-switcher__item .schedule-switcher__link:visited,
.schedule-switcher__item .schedule-switcher__link:active,
.schedule-switcher__item .schedule-switcher__link:hover {
  color: #fff;
  color: var(--schedule-color, #fff);
  text-decoration: none;
  padding-top: 16px;
  padding-bottom: 16px;
  display: block;
}

@media (min-width: 560px) {
  .schedule-switcher__item .schedule-switcher__link,
  .schedule-switcher__item .schedule-switcher__link:visited,
  .schedule-switcher__item .schedule-switcher__link:active,
  .schedule-switcher__item .schedule-switcher__link:hover {
    padding-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .schedule-switcher__item .schedule-switcher__link,
  .schedule-switcher__item .schedule-switcher__link:visited,
  .schedule-switcher__item .schedule-switcher__link:active,
  .schedule-switcher__item .schedule-switcher__link:hover {
    padding-top: 32px;
  }
}

@media (min-width: 560px) {
  .schedule-switcher__item .schedule-switcher__link,
  .schedule-switcher__item .schedule-switcher__link:visited,
  .schedule-switcher__item .schedule-switcher__link:active,
  .schedule-switcher__item .schedule-switcher__link:hover {
    padding-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .schedule-switcher__item .schedule-switcher__link,
  .schedule-switcher__item .schedule-switcher__link:visited,
  .schedule-switcher__item .schedule-switcher__link:active,
  .schedule-switcher__item .schedule-switcher__link:hover {
    padding-bottom: 32px;
  }
}

.has-js .schedule-switcher__item.is-active:after {
  content: " ";
  position: absolute;
  bottom: 0;
  width: 60%;
  left: 20%;
  border-bottom: 4px solid var(--accent-colour);
}

.has-js .schedule-switcher__item.is-active .schedule-switcher__link {
  font-weight: bold;
}

@media all and (min-width: 800px) {
  .schedule-switcher__items {
    max-width: 70vw;
  }
}

@media all and (min-width: 1024px) {
  .schedule-switcher__nav--condensed {
    gap: 16px;
  }
}

@media (min-width: 1024px) and (min-width: 560px) {
  .schedule-switcher__nav--condensed {
    gap: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1024px) and (min-width: 1216px) {
  .schedule-switcher__nav--condensed {
    gap: 32px;
  }
}

.schedule-switcher-header {
  --schedule-color: $color-brand-black;
  text-align: center;
}

.social__services {
  list-style: none;
  display: flex;
  margin: 0;
  padding: 0;
}

.social__service + .social__service {
  margin-left: 16px;
}

.social__label {
  display: none;
}

.social--list .social__services {
  display: block;
}

.social--list .social__label {
  display: block;
}

.social--list .social__link {
  display: flex;
  align-items: flex-start;
}

.social--list .icon {
  width: 32px;
  height: 32px;
  margin-right: 4px;
}

.social--list .social__service + .social__service {
  margin-left: 0;
  margin-bottom: 4px;
}

.speaker-filter {
  font-size: 16px;
}

.speaker-filter label {
  cursor: pointer;
  margin-left: 0.5rem;
  white-space: nowrap;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

.speaker-filter [type=checkbox] {
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(50%);
          clip-path: inset(50%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.speaker-filter span {
  position: relative;
  padding-left: 22px;
}

.speaker-filter span:before {
  content: "";
  width: 15px;
  height: 15px;
  position: absolute;
  border: 2px solid var(--accent-colour);
  left: 0;
  top: 5px;
}

.speaker-filter span:after {
  content: "";
  position: absolute;
  left: 5px;
  top: 8px;
  height: 8px;
  width: 5px;
  border-bottom: 2px solid #FFF;
  border-right: 2px solid #FFF;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  opacity: 0;
}

.speaker-filter [type=checkbox]:checked ~ span:before {
  background: var(--accent-colour);
}

.speaker-filter [type=checkbox]:checked ~ span:after {
  opacity: 1;
}

@media (min-width: 40em) {
  .speaker-filter label {
    margin-left: 1rem;
  }
}

.speaker-talks__talk-meta {
  font-size: 16px;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 1px;
  display: block;
  margin-top: 8px;
}

.speaker-talks__label {
  display: inline-block;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 1px;
  background-color: #ddd;
  line-height: 1;
  padding: 4px 8px 5px 8px;
  font-weight: normal;
  position: relative;
  top: -2px;
  margin-left: 8px;
}

.speaker-talks__talk-title a {
  color: inherit;
  text-decoration: none;
}

.speaker-talks .prose {
  margin-top: 8px;
}

.speaker-talks__talk + .speaker-talks__talk {
  padding-top: 16px;
}

@media (min-width: 560px) {
  .speaker-talks__talk + .speaker-talks__talk {
    padding-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .speaker-talks__talk + .speaker-talks__talk {
    padding-top: 32px;
  }
}

.speakers-list {
  display: flex;
  flex-wrap: wrap;
  margin-right: -8px;
  margin-left: -8px;
  margin-top: -8px;
}

@media (min-width: 560px) {
  .speakers-list {
    margin-right: calc(-1.2195121951vw - 1.1707317073px);
  }
}

@media (min-width: 1216px) {
  .speakers-list {
    margin-right: -16px;
  }
}

@media (min-width: 560px) {
  .speakers-list {
    margin-left: calc(-1.2195121951vw - 1.1707317073px);
  }
}

@media (min-width: 1216px) {
  .speakers-list {
    margin-left: -16px;
  }
}

@media (min-width: 560px) {
  .speakers-list {
    margin-top: calc(-1.2195121951vw - 1.1707317073px);
  }
}

@media (min-width: 1216px) {
  .speakers-list {
    margin-top: -16px;
  }
}

.speakers-list__speaker {
  padding: 8px;
  text-decoration: none;
}

@media (min-width: 560px) {
  .speakers-list__speaker {
    padding: calc(1.2195121951vw + 1.1707317073px);
  }
}

@media (min-width: 1216px) {
  .speakers-list__speaker {
    padding: 16px;
  }
}

.speakers-list__image,
.speakers-list__image img {
  width: 100%;
}

.speakers-list__image {
  background-color: var(--main-colour);
}

.speakers-list__image img {
  mix-blend-mode: screen;
}

.speakers-list__name {
  margin-top: 8px;
}

.speakers-list__role,
.speakers-list__event {
  color: #212227;
  display: block;
  line-height: 1.2;
  margin-top: 4px;
  font-size: 16px;
}

.speakers-list__event {
  margin-top: 0.5rem;
  font-weight: 700;
}

@media all and (min-width: 560px) {
  .speakers-list__speaker {
    flex: 0 0 50%;
  }
}

@media all and (min-width: 800px) {
  .speakers-list__speaker {
    flex: 0 0 33.33333%;
  }
}

@media all and (min-width: 1024px) {
  .speakers-list__speaker {
    flex: 0 0 25%;
  }
}

.sponsors-column > * + * {
  margin-top: 1rem;
}

.sponsors-column__link {
  display: block;
}

.sponsors-column__logo {
  max-height: 5.6rem;
  max-width: 60%;
  margin: 0 auto;
}

.sponsors-detail__sponsor {
  border: 1px solid rgba(33, 34, 39, 0.3);
  padding: 16px;
  align-items: flex-start;
}

@media (min-width: 560px) {
  .sponsors-detail__sponsor {
    padding: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .sponsors-detail__sponsor {
    padding: 32px;
  }
}

.sponsors-detail__logo {
  flex: 0 0 240px;
  width: 240px;
  margin-bottom: 16px;
  padding-right: 32px;
}

@media (min-width: 560px) {
  .sponsors-detail__logo {
    padding-right: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .sponsors-detail__logo {
    padding-right: 64px;
  }
}

.sponsors-detail__label {
  font-size: 16px;
  color: #999;
  margin-bottom: 16px;
  display: block;
}

.sponsors-detail__logo img {
  width: 100%;
  display: block;
}

.sponsors-detail__info {
  flex: 1 1 auto;
}

.sponsors-detail__sponsor + .sponsors-detail__sponsor {
  margin-top: 16px;
}

@media (min-width: 560px) {
  .sponsors-detail__sponsor + .sponsors-detail__sponsor {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .sponsors-detail__sponsor + .sponsors-detail__sponsor {
    margin-top: 32px;
  }
}

@media all and (min-width: 800px) {
  .sponsors-detail__sponsor {
    display: flex;
  }
}

.sponsors-logos__sponsors {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  --sponsor-logo-columns: 2;
}

@supports (display: grid) {
  .sponsors-logos__sponsors {
    display: grid;
    grid-template-columns: repeat(var(--sponsor-logo-columns), 1fr);
    grid-gap: 1rem;
  }
}

.sponsors-logos__item {
  width: 50%;
  text-align: center;
}

@supports (display: grid) {
  .sponsors-logos__item {
    width: auto;
    margin: 0 auto;
  }
}

.sponsors-logos__sponsor {
  margin-left: auto;
  margin-right: auto;
  display: block;
  max-width: 160px;
  margin-bottom: 32px;
  padding-left: 8px;
  padding-right: 8px;
}

@media (min-width: 560px) {
  .sponsors-logos__sponsor {
    padding-left: calc(1.2195121951vw + 1.1707317073px);
  }
}

@media (min-width: 1216px) {
  .sponsors-logos__sponsor {
    padding-left: 16px;
  }
}

@media (min-width: 560px) {
  .sponsors-logos__sponsor {
    padding-right: calc(1.2195121951vw + 1.1707317073px);
  }
}

@media (min-width: 1216px) {
  .sponsors-logos__sponsor {
    padding-right: 16px;
  }
}

.sponsors-logos__logo {
  max-width: 100%;
  max-height: 120px;
  margin: 0 auto;
}

@media all and (min-width: 800px) {
  .sponsors-logos__sponsors {
    --sponsor-logo-columns: 3;
  }

  .sponsors-logos__sponsor {
    max-width: 200px;
  }

  .sponsors-logos__item {
    width: 33.333%;
  }

@supports (display: grid) {
    .sponsors-logos__item {
      width: auto;
    }
}
}

@media all and (min-width: 1024px) {
  .sponsors-logos__item {
    width: 20%;
  }

@supports (display: grid) {
    .sponsors-logos__item {
      width: auto;
    }
}
}

.teaser {
  padding-bottom: 16px;
  text-align: left;
}

@media (min-width: 560px) {
  .teaser {
    padding-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .teaser {
    padding-bottom: 32px;
  }
}

.teaser__image {
  padding-bottom: 16px;
}

@media (min-width: 560px) {
  .teaser__image {
    padding-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .teaser__image {
    padding-bottom: 32px;
  }
}

.teaser__section {
  --link-colour: $color-text-inverse;
  padding-bottom: 16px;
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  text-decoration: none;
}

@media (min-width: 560px) {
  .teaser__section {
    padding-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .teaser__section {
    padding-bottom: 32px;
  }
}

.teaser__section h3 {
  text-decoration: underline;
  text-underline-offset: 4px;
}

.teaser__title {
  color: #fff;
  margin-bottom: 16px;
}

.testimonial {
  color: var(--accent-colour);
  text-align: left;
}

.testimonial__icon {
  width: 106px;
  height: 32px;
  float: right;
  position: relative;
  top: 10px;
}

@media (max-width: 30em) {
  .testimonial__icon {
    width: 55px;
  }
}

.testimonial__text {
  font-size: 23.04px;
  line-height: 1.4;
  letter-spacing: -0.01em;
}

@media (min-width: 560px) {
  .testimonial__text {
    font-size: calc(0.8219512195vw + 18.4370731707px);
  }
}

@media (min-width: 1216px) {
  .testimonial__text {
    font-size: 28.432px;
  }
}

.testimonial__text + * {
  font-size: 0.875rem;
}

.testimonial__text + * ~ * {
  margin-top: 1em;
  font-size: 0.875rem;
}

.testimonial__cite,
.testimonial__cite-image {
  font-weight: 800;
  margin-top: 16px;
  font-style: normal;
  display: block;
}

.testimonial__cite-image {
  display: flex;
  align-items: center;
  font-size: 0.875rem;
}

.testimonial__cite-image img {
  max-width: 100px;
  margin-right: 1rem;
}

.testimonial--muted {
  color: currentColor;
}

.ticket-group__name {
  margin-bottom: 18px;
}

@media (min-width: 560px) {
  .ticket-group__name {
    margin-bottom: calc(0.5073170732vw + 15.1590243902px);
  }
}

@media (min-width: 1216px) {
  .ticket-group__name {
    margin-bottom: 21.328px;
  }
}

.ticket-group__details {
  margin-bottom: 18px;
}

@media (min-width: 560px) {
  .ticket-group__details {
    margin-bottom: calc(0.5073170732vw + 15.1590243902px);
  }
}

@media (min-width: 1216px) {
  .ticket-group__details {
    margin-bottom: 21.328px;
  }
}

.ticket-group__action {
  margin-top: 16px;
  text-align: center;
}

.ticket-group + .ticket-group {
  margin-top: 32px;
}

@media (min-width: 560px) {
  .ticket-group + .ticket-group {
    margin-top: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .ticket-group + .ticket-group {
    margin-top: 64px;
  }
}

.ticket-table {
  width: 100%;
  background-color: var(--main-colour-tint, #eee);
}

.ticket-table__ticket {
  display: flex;
  text-decoration: none;
  color: #212227;
  align-items: center;
  padding-top: 16px;
  padding-bottom: 16px;
  padding-left: 16px;
  padding-right: 16px;
}

@media (min-width: 560px) {
  .ticket-table__ticket {
    padding-left: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .ticket-table__ticket {
    padding-left: 32px;
  }
}

@media (min-width: 560px) {
  .ticket-table__ticket {
    padding-right: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .ticket-table__ticket {
    padding-right: 32px;
  }
}

.ticket-table__ticket + .ticket-table__ticket {
  border-top: 4px solid #fff;
}

.ticket-table__ticket--soldout .ticket-table__label {
  text-decoration: line-through;
  opacity: 0.6;
  font-weight: 400;
}

.ticket-table__ticket--soldout .ticket-table__price {
  font-size: 18px;
  opacity: 0.7;
}

.ticket-table__ticket--soldout .ticket-table__info {
  opacity: 0.7;
}

.ticket-table__price {
  color: #212227;
  flex: none;
  width: 180px;
  margin-left: auto;
  text-align: right;
  text-transform: uppercase;
}

.ticket-table__info {
  color: #212227;
  font-style: italic;
  font-size: 18px;
  opacity: 0.8;
  margin-top: 4px;
}

.travel-options__mode {
  margin-bottom: 8px;
}

.travel-options__title {
  margin-bottom: 16px;
}

@media (min-width: 560px) {
  .travel-options__title {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .travel-options__title {
    margin-bottom: 32px;
  }
}

.travel-options__option + .travel-options__option {
  margin-top: 16px;
}

@media (min-width: 560px) {
  .travel-options__option + .travel-options__option {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .travel-options__option + .travel-options__option {
    margin-top: 32px;
  }
}

.video-grid {
  margin-bottom: -16px;
}

@media (min-width: 560px) {
  .video-grid {
    margin-bottom: calc(-2.4390243902vw - 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .video-grid {
    margin-bottom: -32px;
  }
}

.video-grid__video {
  flex: 1 0 50%;
  margin-bottom: 16px;
}

@media (min-width: 560px) {
  .video-grid__video {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .video-grid__video {
    margin-bottom: 32px;
  }
}

@media all and (max-width: 560px) {
  .video-grid__videos {
    padding-left: 16px;
    padding-right: 16px;
  }
}

@media (max-width: 560px) and (min-width: 560px) {
  .video-grid__videos {
    padding-left: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (max-width: 560px) and (min-width: 1216px) {
  .video-grid__videos {
    padding-left: 32px;
  }
}

@media (max-width: 560px) and (min-width: 560px) {
  .video-grid__videos {
    padding-right: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (max-width: 560px) and (min-width: 1216px) {
  .video-grid__videos {
    padding-right: 32px;
  }
}

@media all and (min-width: 560px) {
  .video-grid__videos {
    display: flex;
    flex-wrap: wrap;
  }

  .video-grid__video {
    flex: 1 0 50%;
  }

  .video-grid__video:nth-child(2n+1) {
    padding-right: 8px;
  }
}

@media (min-width: 560px) and (min-width: 560px) {
  .video-grid__video:nth-child(2n+1) {
    padding-right: calc(1.2195121951vw + 1.1707317073px);
  }
}

@media (min-width: 560px) and (min-width: 1216px) {
  .video-grid__video:nth-child(2n+1) {
    padding-right: 16px;
  }
}

@media all and (min-width: 560px) {
  .video-grid__video:nth-child(2n+2) {
    padding-left: 8px;
  }
}

@media (min-width: 560px) and (min-width: 560px) {
  .video-grid__video:nth-child(2n+2) {
    padding-left: calc(1.2195121951vw + 1.1707317073px);
  }
}

@media (min-width: 560px) and (min-width: 1216px) {
  .video-grid__video:nth-child(2n+2) {
    padding-left: 16px;
  }
}

.articles {
  text-align: center;
}

.articles__blurb {
  margin-top: 16px;
  text-align: center;
}

.articles__articles {
  text-align: left;
}

.articles__article {
  margin-top: 16px;
  padding: 16px;
  text-decoration: none;
  background-color: #f6f6f6;
  background-image: url("/assets/img/bg-article.svg");
  background-repeat: no-repeat;
  background-position: right top;
  justify-content: flex-end;
  display: flex;
  flex-direction: column;
  transition: all 0.2s ease;
}

@media (min-width: 560px) {
  .articles__article {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .articles__article {
    margin-top: 32px;
  }
}

@media (min-width: 560px) {
  .articles__article {
    padding: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .articles__article {
    padding: 32px;
  }
}

.articles__article:hover {
  background-color: #ececec;
}

.articles__title {
  margin-top: auto;
  color: #212227;
  margin-bottom: 8px;
}

.articles__date {
  font-weight: 800;
  color: #00c2aa;
}

.articles__all {
  display: block;
  margin-top: 16px;
}

@media (min-width: 560px) {
  .articles__all {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .articles__all {
    margin-top: 32px;
  }
}

@media all and (max-width: 800px) {
  .articles__article {
    background-size: 120px auto;
  }
}

.banner {
  background-color: var(--accent-colour);
  color: #fff;
  padding-top: 48px;
  padding-bottom: 48px;
}

@media (min-width: 560px) {
  .banner {
    padding-top: calc(7.3170731707vw + 7.0243902439px);
  }
}

@media (min-width: 1216px) {
  .banner {
    padding-top: 96px;
  }
}

@media (min-width: 560px) {
  .banner {
    padding-bottom: calc(7.3170731707vw + 7.0243902439px);
  }
}

@media (min-width: 1216px) {
  .banner {
    padding-bottom: 96px;
  }
}

.banner__content {
  text-align: center;
  max-width: 592px;
  margin: 0 auto;
}

.banner__title {
  margin-bottom: 16px;
  color: #fff;
}

@media (min-width: 560px) {
  .banner__title {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .banner__title {
    margin-bottom: 32px;
  }
}

.banner .button {
  margin-top: 16px;
}

@media (min-width: 560px) {
  .banner .button {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .banner .button {
    margin-top: 32px;
  }
}

.conference-header {
  text-align: center;
  padding-top: 16px;
  padding-bottom: 16px;
  margin-bottom: 48px;
}

@media (min-width: 560px) {
  .conference-header {
    margin-bottom: calc(7.3170731707vw + 7.0243902439px);
  }
}

@media (min-width: 1216px) {
  .conference-header {
    margin-bottom: 96px;
  }
}

.conference-header a,
.conference-header a:visited,
.conference-header a:hover {
  color: var(--accent-colour);
  text-decoration: none;
}

.conference-header__meta {
  color: var(--accent-colour);
  margin-bottom: 32px;
}

.conference-header__title {
  color: currentColor;
  margin-top: -8px;
  font-size: 39.68px;
}

@media (min-width: 560px) {
  .conference-header__title {
    font-size: calc(4.2170731707vw + 16.0643902439px);
  }
}

@media (min-width: 1216px) {
  .conference-header__title {
    font-size: 67.344px;
  }
}

.conference-header__title:first-child {
  margin-top: 32px;
}

@media (min-width: 560px) {
  .conference-header__title:first-child {
    margin-top: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .conference-header__title:first-child {
    margin-top: 64px;
  }
}

.conference-header__title:last-child {
  margin-bottom: 32px;
}

@media (min-width: 560px) {
  .conference-header__title:last-child {
    margin-bottom: calc(7.3170731707vw - 8.9756097561px);
  }
}

@media (min-width: 1216px) {
  .conference-header__title:last-child {
    margin-bottom: 80px;
  }
}

.conference-header__description {
  line-height: 1.1;
  margin: 0 auto;
  margin-top: 32px;
  max-width: 600px;
  font-size: 23.04px;
}

@media (min-width: 560px) {
  .conference-header__description {
    font-size: calc(0.8219512195vw + 18.4370731707px);
  }
}

@media (min-width: 1216px) {
  .conference-header__description {
    font-size: 28.432px;
  }
}

.conference-header__subcontent {
  text-align: center;
  margin-top: 16px;
}

.conference-header__attribution {
  font-size: 16px;
  margin-top: 32px;
}

@media (min-width: 560px) {
  .conference-header__attribution {
    margin-top: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .conference-header__attribution {
    margin-top: 64px;
  }
}

.conference-header__attribution span {
  display: block;
  text-align: center;
  margin-bottom: 10px;
}

.conference-header--home .conference-header__title {
  font-size: 50.512px;
}

@media (min-width: 560px) {
  .conference-header--home .conference-header__title {
    font-size: calc(6.0195121951vw + 16.8027317073px);
  }
}

@media (min-width: 1216px) {
  .conference-header--home .conference-header__title {
    font-size: 90px;
  }
}

* + .conference-header__meta-location {
  margin-left: 11px;
}

* + .conference-header__meta-location:before {
  content: "|";
  margin-right: 16px;
  position: relative;
  top: -1px;
  opacity: 0.8;
}

@media all and (min-width: 800px) {
  .conference-header--wide .conference-header__description {
    max-width: 80%;
  }
}

@media all and (min-width: 1024px) {
  .conference-header--wide .conference-header__description {
    max-width: 920px;
  }
}

.venue-promo {
  position: relative;
}

.venue-promo__image {
  width: 100%;
  background-color: var(--main-colour);
}

.venue-promo__image img {
  width: 100%;
  mix-blend-mode: screen;
}

.venue-promo__panel {
  position: relative;
  z-index: 2;
  background: #fff;
  color: #212227;
  padding: 16px;
}

@media (min-width: 560px) {
  .venue-promo__panel {
    padding: calc(4.8780487805vw - 11.3170731707px);
  }
}

@media (min-width: 1216px) {
  .venue-promo__panel {
    padding: 48px;
  }
}

.venue-promo__label {
  display: block;
  text-align: center;
  opacity: 0.5;
  margin-bottom: 16px;
}

.venue-promo__title {
  text-align: center;
  margin-bottom: 16px;
}

@media (min-width: 560px) {
  .venue-promo__title {
    margin-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .venue-promo__title {
    margin-bottom: 32px;
  }
}

@media all and (min-width: 800px) {
  .venue-promo__image + .venue-promo__panel-wrapper {
    margin-top: -160px;
  }
}

@media (min-width: 800px) and (min-width: 560px) {
  .venue-promo__image + .venue-promo__panel-wrapper {
    margin-top: calc(-24.3902439024vw - 23.4146341463px);
  }
}

@media (min-width: 800px) and (min-width: 1216px) {
  .venue-promo__image + .venue-promo__panel-wrapper {
    margin-top: -320px;
  }
}

.curator h2 {
  line-height: 1;
  margin-bottom: 0.5rem;
  font-size: 27.648px;
}

@media (min-width: 560px) {
  .curator h2 {
    font-size: calc(3.1024390244vw + 10.2743414634px);
  }
}

@media (min-width: 1216px) {
  .curator h2 {
    font-size: 48px;
  }
}

.curator h4 {
  opacity: 0.8;
}

.event-header {
  text-align: center;
}

.event-header__content {
  padding-top: 48px;
  padding-bottom: 176px;
  margin: 0 auto;
  position: relative;
  z-index: 5;
}

@media (min-width: 560px) {
  .event-header__content {
    padding-top: calc(7.3170731707vw + 7.0243902439px);
  }
}

@media (min-width: 1216px) {
  .event-header__content {
    padding-top: 96px;
  }
}

@media (min-width: 560px) {
  .event-header__content {
    padding-bottom: calc(7.3170731707vw + 135.0243902439px);
  }
}

@media (min-width: 1216px) {
  .event-header__content {
    padding-bottom: 224px;
  }
}

.event-header__label {
  margin-bottom: 16px;
}

.event-header__title {
  color: #fff;
}

.event-header__description {
  margin-top: 32px;
  line-height: 1.1;
  font-size: 27.648px;
}

@media (min-width: 560px) {
  .event-header__description {
    font-size: calc(1.5634146341vw + 18.8928780488px);
  }
}

@media (min-width: 1216px) {
  .event-header__description {
    font-size: 37.904px;
  }
}

.event-header--coaching .event-header__title {
  color: #212227;
}

.event-header--image.slat {
  position: relative;
}

.event-header--image.slat:before {
  z-index: 1;
  width: 100%;
  position: absolute;
  max-width: 1367px;
  height: 100%;
  left: 50%;
  top: 0;
  bottom: 0;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  content: "";
  background-color: #000;
}

.event-header--image .event-header__img {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: 1367px auto;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  position: absolute;
  opacity: 0.8;
  z-index: 2;
}

.event-header--image .event-header__content {
  color: #fff;
  padding-top: 80px;
  padding-bottom: 192px;
}

@media (min-width: 560px) {
  .event-header--image .event-header__content {
    padding-top: calc(12.1951219512vw + 11.7073170732px);
  }
}

@media (min-width: 1216px) {
  .event-header--image .event-header__content {
    padding-top: 160px;
  }
}

@media (min-width: 560px) {
  .event-header--image .event-header__content {
    padding-bottom: calc(9.756097561vw + 137.3658536585px);
  }
}

@media (min-width: 1216px) {
  .event-header--image .event-header__content {
    padding-bottom: 256px;
  }
}

@media all and (min-width: 800px) {
  .event-header__content {
    max-width: 80%;
  }
}

@media all and (min-width: 1024px) {
  .event-header__content {
    max-width: 920px;
  }
}

@media all and (max-width: 1216px) {
  .event-header--image .event-header__img {
    background-size: cover;
  }
}

.event-info {
  position: relative;
}

.event-info__panel {
  background-color: #f6f6f6;
  color: #212227;
  padding-top: 16px;
  padding-bottom: 16px;
}

@media (min-width: 560px) {
  .event-info__panel {
    padding-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .event-info__panel {
    padding-top: 32px;
  }
}

@media (min-width: 560px) {
  .event-info__panel {
    padding-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .event-info__panel {
    padding-bottom: 32px;
  }
}

.event-info__icon {
  width: 48px;
  fill: currentColor;
  color: var(--main-colour);
}

.event-info .button {
  margin-top: 16px;
}

.event-info__venue-url {
  display: block;
}

.event-info__message {
  text-align: center;
  width: 100%;
  padding-left: 16px;
  padding-right: 16px;
}

@media (min-width: 560px) {
  .event-info__message {
    padding-left: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .event-info__message {
    padding-left: 32px;
  }
}

@media (min-width: 560px) {
  .event-info__message {
    padding-right: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .event-info__message {
    padding-right: 32px;
  }
}

.event-info--pullup {
  margin-top: -96px;
  z-index: 10;
}

@media all and (max-width: 700px) {
  .event-info__panel {
    display: flex;
    flex-direction: column;
    padding-top: 32px;
    padding-bottom: 32px;
    padding-left: 16px;
    padding-right: 16px;
  }
}

@media (max-width: 700px) and (min-width: 560px) {
  .event-info__panel {
    padding-left: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (max-width: 700px) and (min-width: 1216px) {
  .event-info__panel {
    padding-left: 32px;
  }
}

@media (max-width: 700px) and (min-width: 560px) {
  .event-info__panel {
    padding-right: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (max-width: 700px) and (min-width: 1216px) {
  .event-info__panel {
    padding-right: 32px;
  }
}

@media all and (max-width: 700px) {
  .event-info__section {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    max-width: 400px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}

@media all and (max-width: 700px) {
  .event-info__section + .event-info__section {
    margin-top: 16px;
  }
}

@media all and (max-width: 700px) {
  .event-info__icon {
    flex: none;
    margin-right: 16px;
  }
}

@media all and (max-width: 700px) {
  .event-info__section .button {
    width: 100%;
  }
}

@media all and (max-width: 700px) {
  .event-info__section--what {
    order: 3;
  }
}

@media all and (max-width: 700px) {
  .event-info__section--when {
    order: 2;
  }
}

@media all and (max-width: 700px) {
  .event-info__content {
    width: calc(100% - 64px);
  }
}

@media all and (max-width: 700px) {
  .event-info .button {
    margin-top: 32px;
  }
}

@media all and (min-width: 700px) {
  .event-info__panel {
    display: flex;
    justify-content: center;
    padding-left: 8px;
    padding-right: 8px;
  }
}

@media (min-width: 700px) and (min-width: 560px) {
  .event-info__panel {
    padding-left: calc(1.2195121951vw + 1.1707317073px);
  }
}

@media (min-width: 700px) and (min-width: 1216px) {
  .event-info__panel {
    padding-left: 16px;
  }
}

@media (min-width: 700px) and (min-width: 560px) {
  .event-info__panel {
    padding-right: calc(1.2195121951vw + 1.1707317073px);
  }
}

@media (min-width: 700px) and (min-width: 1216px) {
  .event-info__panel {
    padding-right: 16px;
  }
}

@media all and (min-width: 700px) {
  .event-info__section {
    text-align: center;
    width: 33.33333%;
    padding-left: 8px;
    padding-right: 8px;
  }
}

@media (min-width: 700px) and (min-width: 560px) {
  .event-info__section {
    padding-left: calc(1.2195121951vw + 1.1707317073px);
  }
}

@media (min-width: 700px) and (min-width: 1216px) {
  .event-info__section {
    padding-left: 16px;
  }
}

@media (min-width: 700px) and (min-width: 560px) {
  .event-info__section {
    padding-right: calc(1.2195121951vw + 1.1707317073px);
  }
}

@media (min-width: 700px) and (min-width: 1216px) {
  .event-info__section {
    padding-right: 16px;
  }
}

@media all and (min-width: 700px) {
  .event-info__section > * {
    display: block;
    margin: 0 auto;
  }
}

@media all and (min-width: 700px) {
  .event-info .button {
    display: inline-block;
  }
}

@media all and (min-width: 700px) {
  .event-info__icon {
    margin-bottom: 16px;
    width: 64px;
  }
}

@media all and (min-width: 700px) {
  .event-info__venue-url {
    padding-top: 16px;
  }
}

.flash {
  background-color: var(--main-colour-shade, var(--main-colour));
  font-size: 16px;
  color: #fff;
}

.flash a,
.flash a:visited,
.flash a:hover {
  color: var(--accent-colour);
}

.flash__container {
  padding: 7px 0 9px 0;
  text-align: center;
  position: relative;
}

.flash__message {
  opacity: 0.8;
  padding-right: 30px;
  line-height: 1.3;
}

.flash__close {
  position: absolute;
  right: -10px;
  top: 50%;
  -webkit-transform: translateY(-55%);
          transform: translateY(-55%);
  background: none;
  border: 0;
  color: currentColor;
  cursor: pointer;
}

.flash.is-closed {
  display: none;
}

.footer {
  background-color: var(--main-colour-shade, var(--main-colour));
  color: #fff;
}

.footer a {
  color: #fff;
}

.footer__container {
  border-top: 1px solid rgba(153, 153, 153, 0.5);
  padding-top: 32px;
  padding-bottom: 32px;
}

@media (min-width: 560px) {
  .footer__container {
    padding-top: calc(2.4390243902vw + 18.3414634146px);
  }
}

@media (min-width: 1216px) {
  .footer__container {
    padding-top: 48px;
  }
}

@media (min-width: 560px) {
  .footer__container {
    padding-bottom: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .footer__container {
    padding-bottom: 64px;
  }
}

.footer__nav {
  font-size: 18px;
}

.footer__nav-item + .footer__nav-item {
  margin-top: 3px;
}

.footer .prose {
  font-size: 16px;
  margin-top: 16px;
}

@media (min-width: 560px) {
  .footer .prose {
    margin-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .footer .prose {
    margin-top: 32px;
  }
}

.header {
  background-color: var(--main-colour);
  color: #fff;
  padding-top: 16px;
  padding-bottom: 16px;
}

@media (min-width: 560px) {
  .header {
    padding-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .header {
    padding-top: 32px;
  }
}

@media (min-width: 560px) {
  .header {
    padding-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .header {
    padding-bottom: 32px;
  }
}

.header .logo {
  width: 139px;
  display: block;
  flex: 0 0 auto;
}

@media (min-width: 560px) {
  .header .logo {
    width: calc(7.6219512195vw + 96.3170731707px);
  }
}

@media (min-width: 1216px) {
  .header .logo {
    width: 189px;
  }
}

.header .logo svg {
  width: 100%;
  height: auto;
}

.header__logo {
  position: relative;
}

.header__city {
  position: absolute;
  line-height: 1;
  white-space: nowrap;
  text-decoration: none;
  color: #fff;
  font-size: 19.6px;
  left: 36.7%;
  top: 48%;
}

@media (min-width: 560px) {
  .header__city {
    font-size: calc(1.2804878049vw + 12.4292682927px);
  }
}

@media (min-width: 1216px) {
  .header__city {
    font-size: 28px;
  }
}

.header__city:visited,
.header__city:hover,
.header__city:active {
  color: #fff;
}

.header__container {
  display: flex;
  align-items: center;
  flex-flow: wrap;
  justify-content: space-between;
}

.header__nav {
  display: none;
  list-style: none;
  align-items: center;
}

.header__nav--condensed {
  gap: 0;
}

@media (min-width: 560px) {
  .header__nav--condensed {
    gap: calc(4.8780487805vw - 27.3170731707px);
  }
}

@media (min-width: 1216px) {
  .header__nav--condensed {
    gap: 32px;
  }
}

.header__nav-item {
  margin-left: 16px;
}

@media (min-width: 560px) {
  .header__nav-item {
    margin-left: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .header__nav-item {
    margin-left: 32px;
  }
}

.header__nav-item--condensed {
  margin-left: unset;
}

.header__nav-link,
.header__nav-link:visited,
.header__nav-link:hover,
.header__nav-link:active {
  font-size: 16px;
  display: inline-block;
  color: #fff;
  text-decoration: none;
  padding-bottom: 2px;
  padding-top: 6px;
  border-bottom: 4px solid transparent;
  white-space: nowrap;
}

.header__nav-link:hover {
  border-bottom-color: rgba(255, 255, 255, 0.1);
}

.header__nav-item.cta .header__nav-link {
  border: 1px solid transparent;
  background-color: #fff;
  color: var(--button-text-colour, #212227);
  border-radius: 2em;
  font-weight: 700;
  display: inline-block;
  padding-top: 8px;
  padding-bottom: 8px;
  padding-left: 16px;
  padding-right: 16px;
}

.header__menu-trigger {
  display: block;
  margin-left: auto;
  color: #fff;
}

.header--conference .logo {
  width: 171px;
}

@media (min-width: 560px) {
  .header--conference .logo {
    width: calc(11.1280487805vw + 108.6829268293px);
  }
}

@media (min-width: 1216px) {
  .header--conference .logo {
    width: 244px;
  }
}

.header--inverted {
  background-color: #fff;
  color: #212227;
}

.header--inverted .header__nav-link,
.header--inverted .header__nav-link:visited,
.header--inverted .header__nav-link:hover,
.header--inverted .header__nav-link:active,
.header--inverted .header__menu-trigger {
  color: #212227;
}

.header--inverted .header__nav-link:hover {
  border-bottom-color: rgba(33, 34, 39, 0.1);
}

.header--inverted .header__nav-item.cta .header__nav-link {
  border-color: #212227;
}

.header__nav-link.is-active,
.header--inverted .header__nav-link.is-active {
  text-decoration: none;
  border-bottom-color: var(--accent-colour);
}

.header--conference .header__nav-item.cta .header__nav-link {
  background-color: var(--accent-colour);
}

@media screen and (min-width: 800px) and (max-width: 850px) {
  .header__nav--condensed {
    gap: 0;
  }
}

@media screen and (min-width: 800px) and (max-width: 850px) and (min-width: 560px) {
  .header__nav--condensed {
    gap: calc(3.0487804878vw - 17.0731707317px);
  }
}

@media screen and (min-width: 800px) and (max-width: 850px) and (min-width: 1216px) {
  .header__nav--condensed {
    gap: 20px;
  }
}

@media all and (min-width: 800px) {
  .header__nav {
    display: flex;
  }

  .header__menu-trigger {
    display: none;
  }
}

@media all and (min-width: 1024px) {
  .header__nav-item.cta .header__nav-link {
    padding-left: 16px;
    padding-right: 16px;
  }
}

@media (min-width: 1024px) and (min-width: 560px) {
  .header__nav-item.cta .header__nav-link {
    padding-left: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1024px) and (min-width: 1216px) {
  .header__nav-item.cta .header__nav-link {
    padding-left: 32px;
  }
}

@media (min-width: 1024px) and (min-width: 560px) {
  .header__nav-item.cta .header__nav-link {
    padding-right: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1024px) and (min-width: 1216px) {
  .header__nav-item.cta .header__nav-link {
    padding-right: 32px;
  }
}

@media all and (min-width: 1024px) {
  .header__nav--condensed {
    gap: 16px;
  }
}

@media (min-width: 1024px) and (min-width: 560px) {
  .header__nav--condensed {
    gap: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1024px) and (min-width: 1216px) {
  .header__nav--condensed {
    gap: 32px;
  }
}

.nav-overlay {
  background-color: var(--main-colour-shade, #212227);
  color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100vh;
  z-index: -1;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.1s ease-in;
  overflow-x: auto;
  padding-top: 16px;
  padding-bottom: 16px;
}

html.with-menu .nav-overlay {
  z-index: 100;
  opacity: 1;
  pointer-events: auto;
}

@media (min-width: 560px) {
  .nav-overlay {
    padding-top: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .nav-overlay {
    padding-top: 32px;
  }
}

@media (min-width: 560px) {
  .nav-overlay {
    padding-bottom: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .nav-overlay {
    padding-bottom: 32px;
  }
}

.nav-overlay__nav {
  text-align: center;
  margin-top: 16px;
}

.nav-overlay__nav-item + .nav-overlay__nav-item {
  margin-top: 16px;
}

.nav-overlay__nav-link,
.nav-overlay__nav-link:visited,
.nav-overlay__nav-link:hover,
.nav-overlay__nav-link:active {
  font-size: 23px;
  display: inline-block;
  color: #fff;
  text-decoration: none;
  padding-bottom: 2px;
  padding-top: 6px;
  border-bottom: 4px solid transparent;
  white-space: nowrap;
}

.nav-overlay__nav-link.is-active {
  text-decoration: none;
  border-bottom-color: var(--accent-colour, #d52bb5);
}

.nav-overlay__nav-item.cta {
  margin-top: 48px;
}

.nav-overlay__nav-item.cta .nav-overlay__nav-link {
  border: 1px solid transparent;
  background-color: var(--accent-colour);
  color: #212227;
  border-radius: 2em;
  display: inline-block;
  padding-top: 8px;
  padding-bottom: 8px;
  padding-left: 32px;
  padding-right: 32px;
}

.nav-overlay__close-wrapper {
  height: 72px;
  display: flex;
  justify-content: center;
}

@media (min-width: 560px) {
  .nav-overlay__close-wrapper {
    height: calc(2.743902439vw + 56.6341463415px);
  }
}

@media (min-width: 1216px) {
  .nav-overlay__close-wrapper {
    height: 90px;
  }
}

.nav-overlay__close-trigger {
  display: block;
  margin-left: auto;
  color: #fff;
}

.nav-overlay .social {
  margin-top: 48px;
}

.nav-overlay .social__services {
  justify-content: center;
}

.nav-overlay .social a {
  color: #fff;
}

.nav-overlay--inverted {
  background-color: #fff;
  color: #212227;
}

.nav-overlay--inverted .nav-overlay__nav-link,
.nav-overlay--inverted .nav-overlay__nav-link:visited,
.nav-overlay--inverted .nav-overlay__nav-link:hover,
.nav-overlay--inverted .nav-overlay__nav-link:active,
.nav-overlay--inverted .nav-overlay__close-trigger,
.nav-overlay--inverted .social a {
  color: #212227;
}

.nav-overlay--inverted .nav-overlay__nav-item.cta .nav-overlay__nav-link {
  border-color: #212227;
}

@media all and (min-width: 560px) {
  .nav-overlay__nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    gap: 1rem;
  }

  .nav-overlay__nav-item {
    text-align: center;
    min-width: 24ch;
  }

  .nav-overlay__nav-item + .nav-overlay__nav-item {
    margin-top: 0;
  }

  .nav-overlay__nav-item.cta {
    width: 100%;
    margin-top: 48px;
  }
}

.slat {
  width: 100%;
  background-position: center top;
  background-repeat: repeat-x;
  padding-left: 16px;
  padding-right: 16px;
}

@media (min-width: 560px) {
  .slat {
    padding-left: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .slat {
    padding-left: 32px;
  }
}

@media (min-width: 560px) {
  .slat {
    padding-right: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .slat {
    padding-right: 32px;
  }
}

.slat__container {
  max-width: 1216px;
  margin-left: auto;
  margin-right: auto;
}

.slat__title {
  text-align: center;
}

.slat__blurb {
  text-align: center;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.slat--dark {
  background-color: #212227;
  color: #fff;
}

.slat--dark-branded {
  background-color: #212227;
  color: #fff;
  background-image: url("/assets/img/bg-brand-blend.svg"), linear-gradient(180deg, #212227 0%, #48494d 100%);
}

.slat--upcoming {
  background-color: rgba(0, 194, 170, 0.5);
}

.slat--upcoming .slat__title {
  font-size: 27.648px;
  padding-top: 16px !important;
  padding-bottom: 16px !important;
  border-top: 2px solid currentcolor;
  text-align: left;
}

@media (min-width: 560px) {
  .slat--upcoming .slat__title {
    font-size: calc(1.5634146341vw + 18.8928780488px);
  }
}

@media (min-width: 1216px) {
  .slat--upcoming .slat__title {
    font-size: 37.904px;
  }
}

@media (min-width: 560px) {
  .slat--upcoming .slat__title {
    padding-top: calc(2.4390243902vw + 2.3414634146px) !important;
  }
}

@media (min-width: 1216px) {
  .slat--upcoming .slat__title {
    padding-top: 32px !important;
  }
}

@media (min-width: 560px) {
  .slat--upcoming .slat__title {
    padding-bottom: calc(2.4390243902vw + 2.3414634146px) !important;
  }
}

@media (min-width: 1216px) {
  .slat--upcoming .slat__title {
    padding-bottom: 32px !important;
  }
}

.slat--light-branded {
  background-color: #fff;
  color: #212227;
  background-image: url("/assets/img/bg-brand-light.svg");
}

.slat--themed {
  background-color: var(--main-colour);
  color: #fff;
  background-image: url("/assets/img/bg-brand-blend.svg");
}

.slat--light {
  background-color: #fff;
  color: #212227;
}

.slat--alt {
  background-color: #f6f6f6;
  color: #212227;
}

.slat--padded {
  padding-top: 48px;
  padding-bottom: 48px;
}

@media (min-width: 560px) {
  .slat--padded {
    padding-top: calc(7.3170731707vw + 7.0243902439px);
  }
}

@media (min-width: 1216px) {
  .slat--padded {
    padding-top: 96px;
  }
}

@media (min-width: 560px) {
  .slat--padded {
    padding-bottom: calc(7.3170731707vw + 7.0243902439px);
  }
}

@media (min-width: 1216px) {
  .slat--padded {
    padding-bottom: 96px;
  }
}

.slat--overlaid.slat {
  padding-bottom: 176px;
}

@media (min-width: 560px) {
  .slat--overlaid.slat {
    padding-bottom: calc(7.3170731707vw + 135.0243902439px);
  }
}

@media (min-width: 1216px) {
  .slat--overlaid.slat {
    padding-bottom: 224px;
  }
}

.splash {
  text-align: center;
  /* @include tween(
    'padding-bottom',
    $grid-spacing-min * 3,
    $grid-spacing-max * 3
  ); */
}

.splash__content {
  padding-top: 32px;
  margin: 0 auto;
}

@media (min-width: 560px) {
  .splash__content {
    padding-top: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .splash__content {
    padding-top: 64px;
  }
}

.splash__label {
  margin-bottom: 16px;
}

.splash__title {
  color: currentColor;
}

.splash__description {
  margin-top: 32px;
  line-height: 1.1;
  font-size: 27.648px;
}

@media (min-width: 560px) {
  .splash__description {
    font-size: calc(1.5634146341vw + 18.8928780488px);
  }
}

@media (min-width: 1216px) {
  .splash__description {
    font-size: 37.904px;
  }
}

.splash__body {
  padding-top: 32px;
}

@media (min-width: 560px) {
  .splash__body {
    padding-top: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .splash__body {
    padding-top: 64px;
  }
}

.splash.slat--tight .splash__body {
  padding-top: 48px;
}

@media (min-width: 560px) {
  .splash.slat--tight .splash__body {
    padding-top: calc(7.3170731707vw + 7.0243902439px);
  }
}

@media (min-width: 1216px) {
  .splash.slat--tight .splash__body {
    padding-top: 96px;
  }
}

@media all and (min-width: 800px) {
  .splash__content {
    max-width: 80%;
  }
}

@media all and (min-width: 1024px) {
  .splash__content {
    max-width: 920px;
  }
}

.splash--overlaid {
  padding-bottom: 176px;
}

@media (min-width: 560px) {
  .splash--overlaid {
    padding-bottom: calc(7.3170731707vw + 135.0243902439px);
  }
}

@media (min-width: 1216px) {
  .splash--overlaid {
    padding-bottom: 224px;
  }
}

.updates {
  background-color: var(--main-colour-shade, var(--main-colour));
  color: #fff;
}

.updates a {
  color: #fff;
}

.updates__container {
  padding-bottom: 32px;
  padding-top: 32px;
}

@media (min-width: 560px) {
  .updates__container {
    padding-bottom: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .updates__container {
    padding-bottom: 64px;
  }
}

@media (min-width: 560px) {
  .updates__container {
    padding-top: calc(4.8780487805vw + 4.6829268293px);
  }
}

@media (min-width: 1216px) {
  .updates__container {
    padding-top: 64px;
  }
}

.updates__title {
  color: #fff;
  margin-bottom: 32px;
}

.updates__notification {
  margin-bottom: 16px;
}

.updates .button {
  padding-left: 16px;
  padding-right: 16px;
}

@media (min-width: 560px) {
  .updates .button {
    padding-left: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .updates .button {
    padding-left: 32px;
  }
}

@media (min-width: 560px) {
  .updates .button {
    padding-right: calc(2.4390243902vw + 2.3414634146px);
  }
}

@media (min-width: 1216px) {
  .updates .button {
    padding-right: 32px;
  }
}

@media all and (min-width: 800px) {
  .updates .social {
    display: flex;
    height: 100%;
    align-items: flex-end;
  }
}

@media all and (max-width: 800px) {
  .updates {
    text-align: center;
  }

  .updates .social {
    margin-top: 32px;
  }

  .updates .social__services {
    justify-content: center;
  }
}

