html, body, div, span, applet, object, iframe,
h1, h2, .h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline; }

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

body {
  line-height: 1; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

@font-face {
  font-family: 'Centra No1';
  src: url("/assets/fonts/CentraNo1-BoldItalic.woff2") format("woff2"), url("/assets/fonts/CentraNo1-BoldItalic.woff") format("woff");
  font-weight: bold;
  font-style: italic;
  font-display: swap; }

@font-face {
  font-family: 'Centra No1';
  src: url("/assets/fonts/CentraNo1-Book.woff2") format("woff2"), url("/assets/fonts/CentraNo1-Book.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap; }

@font-face {
  font-family: 'Centra No1';
  src: url("/assets/fonts/CentraNo1-BookItalic.woff2") format("woff2"), url("/assets/fonts/CentraNo1-BookItalic.woff") format("woff");
  font-weight: normal;
  font-style: italic;
  font-display: swap; }

@font-face {
  font-family: 'Centra No1';
  src: url("/assets/fonts/CentraNo1-Bold.woff2") format("woff2"), url("/assets/fonts/CentraNo1-Bold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap; }

@font-face {
  font-family: 'IKANSEEYOUALL';
  src: url("/assets/fonts/IKANSEEYOUALL-AllOfYou.woff2") format("woff2"), url("/assets/fonts/IKANSEEYOUALL-AllOfYou.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap; }

@font-face {
  font-family: 'Ogg';
  src: url("/assets/fonts/Ogg-Italic.woff2") format("woff2"), url("/assets/fonts/Ogg-Italic.woff") format("woff");
  font-weight: normal;
  font-style: italic;
  font-display: swap; }

@font-face {
  font-family: 'Ogg';
  src: url("/assets/fonts/Ogg-Roman.woff2") format("woff2"), url("/assets/fonts/Ogg-Roman.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap; }

:root {
  --fontSuper: 5rem;
  --fontLarge: 3.28rem;
  --fontMedium: 2rem;
  --yellow: #F9D25D;
  --green: #91B17F;
  --orange: #F26A38;
  --beige: #E4CDB1;
  --blue: #6993CC;
  --black: #000;
  --white: #fff;
  --mainpad: 3rem;
  --timing: cubic-bezier(1, 0, .29, 1); }
  @media (max-width : 900px) {
    :root {
      --fontLarge: 2.428571rem;
      --mainpad: 1.071428rem; } }
* {
  box-sizing: border-box; }

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

.visually-hidden {
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
  clip: rect(1px 1px 1px 1px);
  clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap; }

html {
  font-family: 'Centra No1';
  font-size: 14px;
  font-weight: normal;
  font-style: normal;
  line-height: 1.25;
  letter-spacing: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background-color: var(--green); }
  @media (max-width: 420px) {
    html {
      font-size: 3.8vw; } }
@media (max-width: 750px) {
  html, body {
    height: 100%;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch; } }

.pill {
  background-color: var(--orange);
  color: var(--white);
  padding: 1em;
  border-radius: 2em;
  transition: background-color 0.5s;
  white-space: pre;
  cursor: pointer; }
  .pill:hover {
    background-color: var(--blue); }

button {
  background-color: transparent;
  font: inherit;
  border: 0px; }
  button:hover, button:focus, button:focus-within {
    outline: 0; }

header {
  position: fixed;
  height: 200px;
  z-index: 100;
  transition: height 0.5s;
  background-color: var(--yellow); }
  header.compressed {
    height: 100px; }
    header.compressed .logo svg {
      width: 66.666%; }
  header > div {
    align-items: center; }
  header .logo a {
    grid-column: 1/4; }
    @media (max-width: 1100px) {
      header .logo a {
        grid-column: 1/5; } }
    header .logo a svg {
      width: 100%;
      height: auto;
      transition: width 0.5s 0.25s; }
  header nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 100%; }
    header nav a {
      height: max-content;
      font-size: 1.15rem; }
      @media (max-width: 1100px) {
        header nav a {
          font-size: 1rem; } }
  @media (max-width: 1100px) {
    header {
      height: auto;
      flex-direction: row !important; }
      header .minor {
        width: 45% !important; }
      header .major {
        width: 55% !important; }
      header a:not(.pill):not(.logo-link) {
        display: none; } }
body {
  background-color: var(--white); }

h2, .h2 {
  font-family: 'Ogg';
  font-size: var(--fontLarge);
  line-height: 1.2;
  padding-bottom: var(--mainpad); }

p {
  margin-bottom: 1em;
  line-height: 1.4; }

a {
  text-decoration: none;
  color: currentColor; }

ul {
  border-top: 1px solid var(--black);
  width: 66.666%;
  margin-bottom: 1em; }
  ul li {
    border-bottom: 1px solid var(--black);
    padding: 0.5em 0; }

footer {
  background-color: var(--white);
  padding: var(--mainpad);
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: auto;
  grid-column-gap: var(--mainpad);
  align-items: center; }
  @media (max-width : 900px) {
    footer {
      grid-template-columns: repeat(4, 1fr);
      grid-row-gap: calc(2 * var(--mainpad)); } }
  footer svg {
    margin: 0 auto;
    grid-column: 6/8; }

div.buttons {
  position: fixed;
  bottom: var(--mainpad);
  left: var(--mainpad);
  display: flex; }
  div.buttons > *:not(:last-child) {
    margin-right: var(--mainpad); }
  div.buttons .pill {
    background-color: var(--blue); }

div.newsletter_signup {
  background-color: var(--orange);
  color: var(--white);
  padding: 1em;
  border-radius: 2em;
  width: 30ex;
  display: flex;
  flex-direction: row;
  transition: width 0.5s;
  justify-content: space-between; }
  div.newsletter_signup span {
    opacity: 1;
    transition: opacity 0.5s; }
  div.newsletter_signup p {
    margin: 0;
    min-width: 25ex;
    white-space: pre; }
  div.newsletter_signup > div {
    height: 1.4em;
    width: 0;
    overflow-x: hidden; }
    div.newsletter_signup > div form {
      width: max-content; }
      div.newsletter_signup > div form > div {
        display: flex;
        flex-direction: row; }
        div.newsletter_signup > div form > div * {
          background-color: transparent;
          color: var(--white);
          border: 0;
          font-family: inherit; }
        div.newsletter_signup > div form > div .mc-field-group {
          padding-right: 1em; }
        div.newsletter_signup > div form > div input {
          border-bottom: 1px solid var(--white); }
          div.newsletter_signup > div form > div input:focus {
            outline: none; }
          div.newsletter_signup > div form > div input[type="submit"] {
            border: 0px; }
  div.newsletter_signup:hover, div.newsletter_signup:focus, div.newsletter_signup:focus-within {
    width: max-content; }
    div.newsletter_signup:hover span, div.newsletter_signup:focus span, div.newsletter_signup:focus-within span {
      opacity: 0; }
    div.newsletter_signup:hover > div, div.newsletter_signup:focus > div, div.newsletter_signup:focus-within > div {
      width: auto;
      overflow-y: visible; }
  @media (max-width : 900px) {
    div.newsletter_signup {
      display: none; } }
div.registration-form {
  position: fixed;
  top: 100px;
  right: -50vw;
  width: 33.333%;
  background-color: var(--blue);
  height: 100vh;
  padding: var(--mainpad);
  transition: right 1s; }
  div.registration-form button {
    position: absolute;
    right: var(--mainpad);
    top: var(--mainpad); }
  @media (min-width: 450px) {
    div.registration-form {
      min-width: 450px; } }
  @media (max-width : 900px) {
    div.registration-form {
      right: -100vw;
      width: 100vw;
      top: 0; } }
  div.registration-form.active {
    right: 0; }
  div.registration-form p.form-title {
    font-family: 'Ogg';
    font-size: var(--fontLarge); }
  div.registration-form div {
    margin-bottom: 1em; }
  div.registration-form input,
  div.registration-form textarea {
    background-color: transparent;
    width: 100%;
    border: 0;
    border-bottom: 1px solid currentColor;
    color: inherit;
    font: inherit;
    resize: none; }
    div.registration-form input[type="submit"],
    div.registration-form textarea[type="submit"] {
      border: 1px solid currentColor;
      border-radius: 2em;
      padding: 1em;
      cursor: pointer;
      transition: background-color 0.5s; }
      div.registration-form input[type="submit"]:hover,
      div.registration-form textarea[type="submit"]:hover {
        background-color: var(--white); }
    div.registration-form input:hover, div.registration-form input:focus, div.registration-form input:focus-within,
    div.registration-form textarea:hover,
    div.registration-form textarea:focus,
    div.registration-form textarea:focus-within {
      outline: 0; }
    div.registration-form input::placeholder,
    div.registration-form textarea::placeholder {
      color: currentColor;
      opacity: 0.5; }

.mobile {
  display: none; }

@media (max-width : 900px) {
  .desktop {
    display: none; }
  .mobile {
    display: inherit; } }

section {
  min-height: calc(100vh - 100px); }

.landing {
  height: 100vh;
  overflow-y: hidden;
  background: var(--bgColour); }
  .landing .minor {
    padding-top: calc(100px + var(--mainpad));
    padding-bottom: calc(3 * var(--mainpad));
    background-color: var(--bgColour); }
    @media (max-width : 900px) {
      .landing .minor {
        height: calc(100vh - 100px);
        padding-bottom: calc(4 * var(--mainpad)); } }
    .landing .minor div {
      grid-column: 1/5;
      display: flex;
      flex-direction: column;
      justify-content: flex-end; }
      .landing .minor div svg {
        width: 100%; }
  @media (max-width : 900px) {
    .landing {
      height: auto; } }
@media (min-width: 450px) {
  .minor {
    min-width: 450px; } }

.minor > div {
  grid-column: 1/5; }

.splitter {
  display: flex;
  flex-direction: row;
  width: 100vw; }
  .splitter .major {
    width: 66.666%;
    padding: var(--mainpad); }
    .splitter .major.grid {
      display: grid;
      grid-template-columns: repeat(8, 1fr);
      grid-auto-rows: auto;
      column-gap: var(--mainpad); }
  .splitter .minor {
    width: 33.333%;
    padding: var(--mainpad); }
    .splitter .minor.grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      grid-auto-rows: auto;
      column-gap: var(--mainpad); }
      @media (max-width : 900px) {
        .splitter .minor.grid {
          column-gap: 0; } }
  @media (max-width : 900px) {
    .splitter {
      flex-direction: column; }
      .splitter .major, .splitter .minor {
        width: 100%; }
      .splitter .minor {
        order: 1;
        padding: calc(2 * var(--mainpad)) var(--mainpad); }
      .splitter .major {
        order: 2; } }
  .splitter.row-reverse {
    flex-direction: row-reverse; }
    @media (max-width : 900px) {
      .splitter.row-reverse {
        flex-direction: column; } }
.splitter .aspectholder {
  position: relative; }
  .splitter .aspectholder img {
    position: absolute;
    top: 0;
    left: 0;
    object-fit: cover;
    object-position: center;
    height: 100%;
    width: 100%; }
  @media (max-width : 900px) {
    .splitter .aspectholder {
      height: 150vw; } }
.hamburger-outer {
  display: none;
  width: 42.5px;
  height: 42.5px;
  border-radius: 50%;
  background: var(--orange);
  position: relative;
  justify-content: center;
  align-items: center; }
  @media (max-width: 1100px) {
    .hamburger-outer {
      display: flex; } }
.hamburger-menu, .hamburger-menu:after, .hamburger-menu:before {
  width: 22px;
  height: 1px; }

/* middle bar */
.hamburger-menu {
  position: relative;
  background: var(--white);
  /* Top Bar */
  /* Bottom Bar */ }
  .hamburger-menu:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 5px;
    transition: bottom 200ms 200ms cubic-bezier(0.23, 1, 0.32, 1), transform 200ms cubic-bezier(0.23, 1, 0.32, 1);
    background: var(--white); }
  .hamburger-menu:after {
    content: "";
    position: absolute;
    left: 0;
    top: 5px;
    transition: top 200ms 200ms cubic-bezier(0.23, 1, 0.32, 1), transform 200ms cubic-bezier(0.23, 1, 0.32, 1);
    background: var(--white); }

.hamburger-menu.animate {
  background: transparent; }

.hamburger-menu.animate:after {
  top: 0;
  width: 22px;
  transform: rotate(45deg);
  transition: top 200ms cubic-bezier(0.23, 1, 0.32, 1), transform 200ms 200ms cubic-bezier(0.23, 1, 0.32, 1); }

.hamburger-menu.animate:before {
  bottom: 0;
  width: 22px;
  transform: rotate(-45deg);
  transition: bottom 200ms cubic-bezier(0.23, 1, 0.32, 1), transform 200ms 200ms cubic-bezier(0.23, 1, 0.32, 1); }

.mobile-nav {
  height: -webkit-fill-available;
  width: 100%;
  position: fixed;
  z-index: 99;
  top: -100vh;
  padding: 95px var(--mainpad) var(--mainpad);
  left: 0;
  display: none;
  background: var(--yellow);
  flex-direction: column;
  justify-content: center; }
  @media (max-width: 1100px) {
    .mobile-nav {
      display: flex; } }
  .mobile-nav.open {
    top: 0; }
  .mobile-nav > div {
    display: flex;
    flex-direction: column; }

.blocks, .event {
  background: var(--bgColour); }

.event .minor > div {
  display: flex;
  flex-direction: column;
  justify-content: flex-end; }

.event .pill {
  width: fit-content;
  margin-top: 20px;
  background: var(--bgColour);
  border: 1px solid var(--black);
  color: var(--black); }
  .event .pill:hover {
    background: var(--white); }
