/*
 * Website by
  _____                _         _
 |_   _|__  _   _  ___| |__   __| |_ __ ___  __ _ _ __ ___  ___
   | |/ _ \| | | |/ __| '_ \ / _` | '__/ _ \/ _` | '_ ` _ \/ __|
   | | (_) | |_| | (__| | | | (_| | | |  __/ (_| | | | | | \__ \ -
   |_|\___/ \__,_|\___|_| |_|\__,_|_|  \___|\__,_|_| |_| |_|___/ .co.za

 */
/**
 * @file
 * Variables
 */
/* 30em @ 16px font size */
/* 60em @ 16px font size */
/* 60em @ 16px font size */
/* 80em @ 16px font size */
:root {
  --header-stack-width: 850px;
  --site_max_width: 1200px;
  --text-max-width: 40rem;
  --header-height: 60px;
  --nav-height: 40px;
  --footer-height: 100px;
  --sidebar-width: 25%;
  /* used in width functions */
  --w-narrow: 480px;
  --w-regular: 960px;
  --w-average: 960px;
  --w-wide: 1200px;
  --gutter-narrow: 3vw;
  --gutter-regular: 5vw;
  --gutter-wide: 7vw;
  --site_padding-narrow: 5%;
  --pointer_target-padding: 0.6em 0.8em;
  --pointer_target-line-height: 1.3em; /* Assuming font-size: 1rem; */
  --data-field-padding: 0.5em 0.7em; /* used by table cells and text fields */
  --corner_radius-large: 8px;
  --corner_radius-regular: 5px;
  --corner_radius-small: 3px;
  --transition-duration-regular: 0.4s;
}

:root {
  --font-size: 1em;
  --line-height: 1.4;
  --font-size-h1: calc(1.5em + 1vw);
  --font-size-h1-max: 2em;
  --font-size-h2: calc(1.2em + 0.7vw);
  --font-size-h3: calc(1em + 0.5vw);
  --font-size-h4: calc(0.9em + 0.35vw);
  --font-size-h5: 0.83em;
  --font-size-h6: 0.67em;
  --line-height-h1: 1;
  --line-height-h2: 1.15;
  --line-height-h3: 1.3;
  --line-height-h4: 1.38;
  --line-height-h5: 1.45;
  --line-height-h6: 1.5;
}

:root {
  --font-sans: "Open Sans", sans-serif;
  --font-body: var(--font-sans);
  --font-headings: var(--font-body);
  --menu-case: initial;
  --font-weight-body: 400;
  --font-weight-links: 600;
}

:root {
  --colour-near_white: #f5f5f5;
  --colour-dark_grey: #444;
  --colour-medium_grey: #999;
  --colour-dividers: rgba(0, 0, 0, 0.2);
  --colour-selection: #40b6ff;
  --colour-danger: #c72100;
  --colour-error: #e62600;
  --colour-warning: #e09600;
  --colour-success: #77b259;
  --colour-unpublished: #CF5541;
  --colour-primary: #904091;
  /* Social media */
}

:root {
  --colour-secondary: var(--colour-medium_grey);
  --colour-primary-dark: var(--colour-primary);
  --colour-primary-light: var(--colour-primary);
  --colour-primary-lightest: var(--colour-primary);
  --colour-primary-pale: var(--colour-primary);
  --colour-bg-body: white;
  --colour-text-body: var(--colour-dark_grey);
  --colour-links: #2E6088;
  --colour-subtle: var(--colour-text-body);
  --colour-banner: var(--colour-primary-dark);
  --colour-bg-footer: var(--colour-dark_grey);
  --colour-text-footer: var(--colour-medium_grey);
}

/** ----------------------------------------------------------------------------
 * Originally from the Zen theme.
 */
/* element-invisible as defined by http://snook.ca/archives/html_and_css/hiding-content-for-accessibility */
.element-invisible,
.element-focusable {
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

/* Turns off the element-invisible effect. */
.element-focusable:active, .element-focusable:focus {
  position: static !important;
  clip: auto;
  height: auto;
  width: auto;
  overflow: auto;
}

.background-dark {
  color: white;
}
.background-dark a {
  color: inherit;
}
.background-dark a:hover, .background-dark a:focus {
  color: inherit;
}

/*
  Originally based on Formalize.
*/
form, main form[class*=webform] {
  --form-horiz_gap: 3%;
  --form-first_w: 40%;
  --form-second_w: calc(100% - var(--form-first_w) - var(--form-horiz_gap));
  --form-v-margin: 0.8em;
  max-width: var(--text-max-width);
  margin-left: auto;
  margin-right: auto;
}
form.width-narrow, main form.width-narrow[class*=webform] {
  max-width: 30em;
}

/*------------------------------------------------------------------------
                              UI Consistency
*/
input[type=search]::-webkit-search-decoration {
  display: none;
}

input:invalid,
select:invalid,
textarea:invalid {
  box-shadow: none;
}
input:focus,
select:focus,
textarea:focus {
  outline: solid 2px rgba(44, 118, 201, 0.9);
}

input[type=file]:focus, input[type=file]:active,
input[type=radio]:focus,
input[type=radio]:active,
input[type=checkbox]:focus,
input[type=checkbox]:active {
  box-shadow: none;
}

.form-checkboxes:after,
.form-radios:after {
  content: "";
  display: table;
  clear: both;
}

fieldset {
  border: 1px solid #ccc;
  margin-top: 1em;
  margin-bottom: 1em;
  padding-top: 0;
  padding-bottom: 0;
}
fieldset legend {
  font-weight: bold;
  margin-top: 0.3em;
  margin-bottom: 0.3em;
  padding: 0 0.5em;
}
* + fieldset {
  margin-top: 3em;
}

input[type=radio],
input[type=checkbox] {
  margin-top: 0.3em;
}

label {
  display: inline-block;
}
input[type=radio] + label, input[type=checkbox] + label {
  min-width: 0;
  padding-left: 0.2em;
}

/*------------------------------------------------------------------------
                              Text Fields
*/
textarea,
select,
input[type=date],
input[type=datetime],
input[type=datetime-local],
input[type=email],
input[type=month],
input[type=number],
input[type=password],
input[type=search],
input[type=tel],
input[type=text],
input[type=time],
input[type=url],
input[type=week] {
  box-sizing: border-box;
  background-clip: padding-box;
  border-radius: var(--corner_radius-small);
  -webkit-appearance: none;
  background-color: #f4f5f5;
  border: 1px solid;
  border-color: #848484 #c1c1c1 #e1e1e1;
  color: black;
  margin: 0;
  padding: var(--data-field-padding);
  text-align: left;
  font-size: 0.9em;
  height: auto;
  vertical-align: top;
  max-width: 100%;
  min-width: 5em;
}
textarea[disabled],
select[disabled],
input[type=date][disabled],
input[type=datetime][disabled],
input[type=datetime-local][disabled],
input[type=email][disabled],
input[type=month][disabled],
input[type=number][disabled],
input[type=password][disabled],
input[type=search][disabled],
input[type=tel][disabled],
input[type=text][disabled],
input[type=time][disabled],
input[type=url][disabled],
input[type=week][disabled] {
  background-color: #eee;
}

.resizable-textarea textarea {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

/*------------------------------------------------------------------------
                              Other
*/
button[disabled],
input[disabled],
select[disabled],
select[disabled] option,
select[disabled] optgroup,
textarea[disabled],
a.button_disabled {
  box-shadow: none;
  -moz-user-select: -moz-none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  user-select: none;
  color: #888;
  cursor: default;
}

input::-webkit-input-placeholder,
textarea::-webkit-input-placeholder {
  color: #888;
}

input:-moz-placeholder,
textarea:-moz-placeholder {
  color: #888;
}

input.placeholder_text,
textarea.placeholder_text {
  color: #888;
}

textarea,
select[size],
select[multiple] {
  height: auto;
}

/*------------------------------------------------------------------------
                              Select lists
*/
select[size="0"],
select[size="1"] {
  height: 1.8em;
}

@media (-webkit-min-device-pixel-ratio: 0) {
  select[size],
  select[multiple],
  select[multiple][size] {
    background-image: none;
    padding-right: 3px;
  }
  select,
  select[size="0"],
  select[size="1"] {
    background-image: url(data:image/png;base64,R0lGODlhDQAEAIAAAAAAAP8A/yH5BAEHAAEALAAAAAANAAQAAAILhA+hG5jMDpxvhgIAOw==);
    background-repeat: no-repeat;
    background-position: right center;
    padding-right: 20px;
  }
  ::-webkit-validation-bubble-message {
    -webkit-box-shadow: none;
    box-shadow: none;
    border: 0;
    color: white;
    overflow: hidden;
    padding: 15px 15px 17px;
    text-shadow: black 0 0 1px;
    min-height: 16px;
  }
  ::-webkit-validation-bubble-arrow,
  ::-webkit-validation-bubble-top-outer-arrow,
  ::-webkit-validation-bubble-top-inner-arrow {
    -webkit-box-shadow: none;
    box-shadow: none;
    background: #666;
    border-color: #666;
  }
}
/*------------------------------------------------------------------------
                              Other elements
*/
textarea {
  min-height: 40px;
  overflow: auto;
  resize: vertical;
  width: 100%;
}

optgroup {
  color: black;
  font-style: normal;
  font-weight: normal;
}
optgroup::-moz-focus-inner {
  border: 0;
  padding: 0;
}

/*------------------------------------------------------------------------
                              Search forms
*/
form[action="/search"]:not([class*=exposed]) {
  position: relative;
}
form[action="/search"]:not([class*=exposed])::before {
  content: "";
  background-image: url("../images/icons/search.svg") !important;
  background-position: 4px 50% !important;
  background-size: 20px;
  padding-left: 27px;
  background-repeat: no-repeat;
  position: absolute;
  z-index: 10;
  width: 16px;
  height: 16px;
  top: 0.65em;
  left: 0.3em;
}
form[action="/search"]:not([class*=exposed]) input.form-autocomplete {
  background-position: right 8px center !important;
}

.region-header form[action*=search] [type=submit],
.region-search-pane form[action*=search] [type=submit] {
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

body.path-search .views-row + .views-row {
  margin-top: 0;
}

/*
  Website   Touchdreams
  Author    Dane Rossenrode
  Creation  April 2013
  Updated   October 2014
*/
/* -------------------------------------------------------------------------------------------
                                CONTENTS
  Individual tags
  Headings
  Forms
  Links
  Tables
  Lists
 */
/* -------------------------------------------------------------------------------------------
                                HTML5 Boilerplate: Base styles: opinionated defaults
*/
/*! HTML5 Boilerplate v4.3.0 | MIT License | http://h5bp.com/ */
/*
 * What follows is the result of much research on cross-browser styling.
 * Credit left inline and big thanks to Nicolas Gallagher, Jonathan Neal,
 * Kroc Camen, and the H5BP dev community and team.
 */
html {
  font-size: 1em;
  line-height: 1.4;
}

/*
 * Remove text-shadow in selection highlight: h5bp.com/i
 * These selection rule sets have to be separate.
 * Customize the background color to match your design.
 */
::-moz-selection {
  background: #b3d4fc;
  text-shadow: none;
}

::selection {
  background: #b3d4fc;
  text-shadow: none;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
}
hr[aria-orientation=vertical] {
  border-width: 0 1px 0 0;
  border-style: solid;
  width: 0;
}

/*
 * Remove the gap between images, videos, audio and canvas and the bottom of
 * their containers: h5bp.com/i/440
 */
audio,
canvas,
img,
video {
  vertical-align: middle;
}

/*
 * Allow only vertical resizing of textareas.
 */
textarea {
  resize: vertical;
}

/* -------------------------------------------------------------------------------------------
                                Individual tags
*/
html {
  font-size: 16px;
}

body {
  margin: 0;
  background: var(--colour-bg-body) repeat;
  font-family: var(--font-body);
  color: var(--colour-text-body);
}
@media only screen and (max-width: 960px) {
  body {
    font-size: 0.92em;
  }
}
@media only screen and (max-width: 480px) {
  body {
    font-size: 0.86em;
  }
}

* + p {
  margin-top: 1.2em;
}

img {
  max-width: 100%;
  height: auto;
}

figure {
  position: relative;
}

.centreimage,
.rightimage,
.leftimage,
figcaption {
  /*box-sizing: border-box;
  text-align: center;
  background-color: rgba( black, 0.6);
  line-height: 1.2;
  padding: 0.3em 0.5em;
  color: #FFF;*/
  font-size: 0.8rem;
  color: #993366;
}
.centreimage:last-child,
.rightimage:last-child,
.leftimage:last-child,
figcaption:last-child {
  margin-bottom: 0;
}
.centreimage .title,
.rightimage .title,
.leftimage .title,
figcaption .title {
  font-weight: bold;
  margin-top: 0;
  margin-bottom: 0.3em;
}

figure figcaption {
  /*position: absolute;
  display: block;
  width: 100%;
  bottom: 0px;*/
  caption-side: bottom;
  width: 100%;
  margin-top: 0.6em;
}

acronym, abbr {
  border-bottom: 1px dotted #222;
  cursor: help;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid var(--colour-dividers);
  margin: 1em 0;
  padding: 0;
  width: 70%;
  margin: 2.6em auto;
}

mark {
  background: #f2f2a3;
  padding: 0.2em 0.7em;
  text-transform: uppercase;
  display: inline-block;
  font-size: 0.6rem;
}

iframe {
  width: 100%;
}
iframe.media-oembed-content, iframe[src*="youtube.com"] {
  height: auto;
  aspect-ratio: 16/9;
}

pre {
  background: #e4e8ea;
  border: solid 1px #a4b2b9;
  border-radius: 8px;
  padding: 0.7em 1em;
}

/*------------------------------------------------------------------------
                              Links
*/
a {
  color: var(--colour-links);
  text-decoration: none;
  word-wrap: break-word;
  font-weight: 600;
}
a:hover, a:focus {
  color: var(--colour-links);
  text-decoration: underline;
}
a:active { /* a link when it is 'clicked' on */
  color: var(--colour-links);
}
a.active, a[aria-selected=true] {
  font-weight: bold;
  color: inherit;
}

/*------------------------------------------------------------------------
                              Headings
*/
h1, h2, h3, h4 {
  font-family: var(--font-headings);
  line-height: 1.1;
  color: #212121;
  margin-top: 1.2em;
  margin-bottom: 0.6em;
}
h1 a, h2 a, h3 a, h4 a {
  color: inherit;
  font-weight: inherit;
}

h3, h4 {
  font-weight: 600;
}

h1 {
  font-size: min(var(--font-size-h1), var(--font-size-h1-max));
  line-height: var(--line-height-h1);
  text-align: center;
  margin-top: 0;
  margin-bottom: 1em;
}
h1 * {
  display: inline;
}

h2 {
  font-size: var(--font-size-h2);
  line-height: var(--line-height-h2);
}

h3 {
  font-size: var(--font-size-h3);
  line-height: var(--line-height-h3);
}

h4 {
  font-size: var(--font-size-h4);
  line-height: var(--line-height-h4);
}

/* -------------------------------------------------------------------------------------------
                                Tables
*/
table {
  border-collapse: collapse;
  font-size: 0.9em;
  margin: 1.5em 0;
}
table[style*=inline] {
  display: inline-block !important;
}
table td, table th {
  border: solid 1px #bbb;
  padding: var(--data-field-padding);
}
table.borderless td, table.borderless th {
  border: none;
}
table th {
  text-align: left;
  font-weight: bold;
  background: rgba(0, 0, 0, 0.05);
}
table th.active {
  background: rgba(0, 0, 0, 0.15);
}
table th[scope=row] {
  font-weight: bold;
  text-align: right;
}
table thead {
  font-size: 1.1em;
  font-family: var(--font-headings);
  font-weight: bold;
  text-transform: uppercase;
}
table .even {
  background: none;
}
table .odd {
  background: none;
}

/* -------------------------------------------------------------------------------------------
                                Lists
*/
ul,
ol {
  /*line-height: 1.1;*/
}
ul.non-list,
ol.non-list {
  list-style: none;
  padding-left: 0;
  margin: 0;
}
ul.non-list li,
ol.non-list li {
  padding-left: 0;
  line-height: inherit;
}

li + li {
  margin-top: 0.5em;
}

menu li + li {
  margin-top: 0;
}

nav ul li {
  margin: 0;
}

ul.buttons {
  padding: 0;
}
ul.buttons li {
  display: inline-block;
}
ul.buttons img {
  border-radius: var(--corner_radius-small);
}

/**
 * @file
 * Positioning for a responsive layout.
 *
 */
/**
 * @file
 * Variables
 */
/* 30em @ 16px font size */
/* 60em @ 16px font size */
/* 60em @ 16px font size */
/* 80em @ 16px font size */
:root {
  --header-stack-width: 850px;
  --site_max_width: 1200px;
  --text-max-width: 40rem;
  --header-height: 60px;
  --nav-height: 40px;
  --footer-height: 100px;
  --sidebar-width: 25%;
  /* used in width functions */
  --w-narrow: 480px;
  --w-regular: 960px;
  --w-average: 960px;
  --w-wide: 1200px;
  --gutter-narrow: 3vw;
  --gutter-regular: 5vw;
  --gutter-wide: 7vw;
  --site_padding-narrow: 5%;
  --pointer_target-padding: 0.6em 0.8em;
  --pointer_target-line-height: 1.3em; /* Assuming font-size: 1rem; */
  --data-field-padding: 0.5em 0.7em; /* used by table cells and text fields */
  --corner_radius-large: 8px;
  --corner_radius-regular: 5px;
  --corner_radius-small: 3px;
  --transition-duration-regular: 0.4s;
}

:root {
  --font-size: 1em;
  --line-height: 1.4;
  --font-size-h1: calc(1.5em + 1vw);
  --font-size-h1-max: 2em;
  --font-size-h2: calc(1.2em + 0.7vw);
  --font-size-h3: calc(1em + 0.5vw);
  --font-size-h4: calc(0.9em + 0.35vw);
  --font-size-h5: 0.83em;
  --font-size-h6: 0.67em;
  --line-height-h1: 1;
  --line-height-h2: 1.15;
  --line-height-h3: 1.3;
  --line-height-h4: 1.38;
  --line-height-h5: 1.45;
  --line-height-h6: 1.5;
}

:root {
  --font-sans: "Open Sans", sans-serif;
  --font-body: var(--font-sans);
  --font-headings: var(--font-body);
  --menu-case: initial;
  --font-weight-body: 400;
  --font-weight-links: 600;
}

:root {
  --colour-near_white: #f5f5f5;
  --colour-dark_grey: #444;
  --colour-medium_grey: #999;
  --colour-dividers: rgba(0, 0, 0, 0.2);
  --colour-selection: #40b6ff;
  --colour-danger: #c72100;
  --colour-error: #e62600;
  --colour-warning: #e09600;
  --colour-success: #77b259;
  --colour-unpublished: #CF5541;
  --colour-primary: #904091;
  /* Social media */
}

:root {
  --colour-secondary: var(--colour-medium_grey);
  --colour-primary-dark: var(--colour-primary);
  --colour-primary-light: var(--colour-primary);
  --colour-primary-lightest: var(--colour-primary);
  --colour-primary-pale: var(--colour-primary);
  --colour-bg-body: white;
  --colour-text-body: var(--colour-dark_grey);
  --colour-links: #2E6088;
  --colour-subtle: var(--colour-text-body);
  --colour-banner: var(--colour-primary-dark);
  --colour-bg-footer: var(--colour-dark_grey);
  --colour-text-footer: var(--colour-medium_grey);
}

.page-max-width {
  margin-left: auto;
  margin-right: auto;
  width: 88%;
  max-width: 1200px;
}

.site-max-width > * {
  margin-left: auto;
  margin-right: auto;
  width: 88%;
  max-width: 1200px;
}

.text-max-width > * {
  margin-left: auto;
  margin-right: auto;
  width: 88%;
  max-width: 1200px;
  max-width: 40rem;
}

[id=pre-header] > *,
[id=primary-nav] > *,
[id=highlighted] > *,
footer[role=contentinfo] > *,
[id=post-footer] > * {
  margin-left: auto;
  margin-right: auto;
  width: 88%;
  max-width: 1200px;
}

/*article[data-view-mode="full"] {
  & > * {
    @include text-max-width;
  }
}*/
.view-empty,
.feed-icons {
  margin-left: auto;
  margin-right: auto;
  width: 88%;
  max-width: 1200px;
  max-width: 30em;
  text-align: center;
}

/*article.profile {
  @include page-max-width;
}*/
form[class^=user-], main form[class^=user-][class*=webform],
form[class^=contact-],
main form[class^=contact-][class*=webform] {
  max-width: 40rem;
  margin-left: auto;
  margin-right: auto;
}

.search-form,
.search-form + h2,
.search-results {
  max-width: 40rem;
  margin-left: auto;
  margin-right: auto;
}

.search-results li {
  margin-left: 0;
}

[id=highlighted] > :first-child {
  margin-top: 1.2vw;
}

[id=body] {
  margin-left: auto;
  margin-right: auto;
  width: 88%;
  max-width: 1200px;
  margin-top: calc(1.2em + 4vw);
  margin-bottom: calc(1.2em + 4vw);
}
@media (min-width: 850px) {
  [id=body] {
    display: flex;
    gap: 60px;
    align-items: flex-start;
  }
  [id=body] > * {
    flex: 1 1 0;
  }
  [id=body] aside.first {
    order: 1;
  }
  [id=body] main {
    order: 2;
  }
  [id=body] aside.second {
    order: 2;
  }
  [id=body] > aside, [id=body] > code {
    width: 29%;
    flex-basis: auto;
    flex-grow: 0;
  }
}

/** ----------------------------------------------------------------------------
 *                              Sticky footer
 */
.layout-container {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
.layout-container > * {
  flex: 0 1 auto;
}
.layout-container [id=body] {
  flex-grow: 1;
}

/** ----------------------------------------------------------------------------
 *                              Sidebar
*/
@media all and (min-width: 800px) {
  .page-content > [role=presentation] {
    display: flex;
  }
  .page-content > [role=presentation] > * {
    flex: 1 1 auto;
  }
  .page-content > [role=presentation] > *:not(:first-child) {
    margin-left: var(--gutter-wide);
  }
  .page-content main[data-primary] {
    width: 100%-var(--sidebar-width);
  }
  .page-content aside[role=complementary] {
    width: var(--sidebar-width);
  }
}

/**
 * Using Layout Builder in Drupal core.
 */
/**
 * @file
 * Variables
 */
/* 30em @ 16px font size */
/* 60em @ 16px font size */
/* 60em @ 16px font size */
/* 80em @ 16px font size */
:root {
  --header-stack-width: 850px;
  --site_max_width: 1200px;
  --text-max-width: 40rem;
  --header-height: 60px;
  --nav-height: 40px;
  --footer-height: 100px;
  --sidebar-width: 25%;
  /* used in width functions */
  --w-narrow: 480px;
  --w-regular: 960px;
  --w-average: 960px;
  --w-wide: 1200px;
  --gutter-narrow: 3vw;
  --gutter-regular: 5vw;
  --gutter-wide: 7vw;
  --site_padding-narrow: 5%;
  --pointer_target-padding: 0.6em 0.8em;
  --pointer_target-line-height: 1.3em; /* Assuming font-size: 1rem; */
  --data-field-padding: 0.5em 0.7em; /* used by table cells and text fields */
  --corner_radius-large: 8px;
  --corner_radius-regular: 5px;
  --corner_radius-small: 3px;
  --transition-duration-regular: 0.4s;
}

:root {
  --font-size: 1em;
  --line-height: 1.4;
  --font-size-h1: calc(1.5em + 1vw);
  --font-size-h1-max: 2em;
  --font-size-h2: calc(1.2em + 0.7vw);
  --font-size-h3: calc(1em + 0.5vw);
  --font-size-h4: calc(0.9em + 0.35vw);
  --font-size-h5: 0.83em;
  --font-size-h6: 0.67em;
  --line-height-h1: 1;
  --line-height-h2: 1.15;
  --line-height-h3: 1.3;
  --line-height-h4: 1.38;
  --line-height-h5: 1.45;
  --line-height-h6: 1.5;
}

:root {
  --font-sans: "Open Sans", sans-serif;
  --font-body: var(--font-sans);
  --font-headings: var(--font-body);
  --menu-case: initial;
  --font-weight-body: 400;
  --font-weight-links: 600;
}

:root {
  --colour-near_white: #f5f5f5;
  --colour-dark_grey: #444;
  --colour-medium_grey: #999;
  --colour-dividers: rgba(0, 0, 0, 0.2);
  --colour-selection: #40b6ff;
  --colour-danger: #c72100;
  --colour-error: #e62600;
  --colour-warning: #e09600;
  --colour-success: #77b259;
  --colour-unpublished: #CF5541;
  --colour-primary: #904091;
  /* Social media */
}

:root {
  --colour-secondary: var(--colour-medium_grey);
  --colour-primary-dark: var(--colour-primary);
  --colour-primary-light: var(--colour-primary);
  --colour-primary-lightest: var(--colour-primary);
  --colour-primary-pale: var(--colour-primary);
  --colour-bg-body: white;
  --colour-text-body: var(--colour-dark_grey);
  --colour-links: #2E6088;
  --colour-subtle: var(--colour-text-body);
  --colour-banner: var(--colour-primary-dark);
  --colour-bg-footer: var(--colour-dark_grey);
  --colour-text-footer: var(--colour-medium_grey);
}

.block-layout-builder[class*=background-] {
  padding: 20px;
}

.block-inline-blockimage .field {
  text-align: center;
}
.block-inline-blockimage .field--name-field-text {
  margin-top: 0.6em;
}

.layout-builder__message--overrides .messages {
  background-image: none;
}

.layout {
  display: grid;
  grid-gap: calc(10px + 4vw);
}
.layout h2 {
  margin-top: 0;
}
.layout p:last-child {
  margin-bottom: 0;
}
.layout.page-max-width {
  margin-left: auto;
  margin-right: auto;
  width: 88%;
  max-width: 1200px;
}
.layout.no-gaps {
  grid-gap: 0;
}

/* one-third-two-thirds,*/
.layout[class*="-33-67"] {
  display: grid;
  grid-gap: 6%;
  grid-auto-flow: dense;
}
@media all and (min-width: 750px) {
  .layout[class*="-33-67"] {
    grid-template-columns: 30% 64%;
  }
}
.layout[class*="-33-67"].image-side-right .one-third {
  grid-column-start: 2;
}

/**
 * @file
 * Small helper classes.
 */
.visually-hidden:not(:focus):not(:active) {
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

@media (max-width: 850px) {
  .hide-on-small {
    display: none !important;
  }
}

@media (min-width: 850px) {
  .hide-on-large {
    display: none !important;
  }
}

a[role=block] {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

.between-sections {
  margin: 0 !important;
}
@media (min-width: 850px) {
  .between-sections {
    position: absolute;
    transform: translateY(-50%) translateX(-50%);
    left: 50%;
  }
}

.raised {
  max-width: 100% !important;
  border-bottom: solid 2px var(--colour-primary);
  background: white;
  box-shadow: rgba(0, 0, 0, 0.14) 0 1px 5px 0;
  padding: 0.8em 1em;
  box-sizing: border-box;
  width: 100% !important;
}
@media (min-width: 850px) {
  .raised {
    width: 750px !important;
  }
}

span.separator {
  color: var(--colour-primary);
}

.heading {
  background: #3c3c3c;
  color: white;
  margin-top: 2em;
  margin-bottom: 1em;
  padding: 0.7em 0.8em 0.6em;
  font-size: 0.85em;
  text-transform: uppercase;
}

a.wp-element-button[href*="podcasts.apple.com"], a.wp-element-button[href*="spotify.com"], a.wp-element-button[href*="podbean.com"] {
  border-radius: 1.5em;
  margin-top: 0;
  background: #3c3c3c;
  padding: 0.7em 1.1em;
}

a.wp-element-button[href*="spotify.com"] {
  background: #1dd05d;
}

a.wp-element-button[href*="podbean.com"] {
  background: #7ac22b;
}

/* -----------------------------------------------------------------------------
                              Tailwind-inspired
*/
.mt-0, .my-0 {
  margin-top: 0;
}

.mb-0, .my-0 {
  margin-bottom: 0;
}

/* -----------------------------------------------------------------------------
                              Dark areas
*/
.background-dark {
  background-color: var(--colour-dark_grey);
  color: white;
}
.background-dark a {
  color: inherit;
}
.background-dark a:hover, .background-dark a:focus {
  color: inherit;
  text-decoration: underline;
}

/* -----------------------------------------------------------------------------
                              Rotations
*/
[data-rotated="90deg"],
[data-rotated="-270deg"] {
  transform: rotate(90deg);
}

[data-rotated="180deg"] {
  transform: rotate(180deg);
}

[data-rotated="270deg"],
[data-rotated="-90deg"] {
  transform: rotate(270deg);
}

.subtle {
  color: var(--colour-subtle);
}

/* -----------------------------------------------------------------------------
                              Overlap-bottom (labels)
*/
/* -----------------------------------------------------------------------------
                              Left and right floats
*/
.left,
.right {
  z-index: 1;
  position: relative;
}

.left {
  float: left;
  margin: 0 2em 2em 0;
}
.left.small {
  margin: 0 1em 1em 0;
}

.right {
  float: right;
  margin: 0 0 2em 2em;
}

@media all and (max-width: 480px) {
  .left,
  .right {
    float: none;
    margin-left: 0;
    margin-right: 0;
    text-align: center;
  }
}
.align-center {
  text-align: center;
}

a[rel=more],
a.more,
.more-link {
  text-align: right; /* LTR */
  float: right;
}

.floating {
  position: absolute;
  z-index: 20;
  margin-left: 1em;
}

mark.unpublished {
  display: block;
  height: auto;
  text-align: left;
  font-family: inherit;
  font-size: 1.5em;
  color: white;
  background-color: var(--colour-unpublished);
  padding: 0.5em 0.6em;
}

/* List of links generated by theme_links(). */
.inline {
  display: inline;
  padding: 0;
}
.inline li {
  display: inline;
  list-style-type: none;
  padding: 0 1em 0 0; /* LTR */
}

/* The inline field label used by the Fences module. */
span.field-label {
  padding: 0 1em 0 0; /* LTR */
}

.comment {
  max-width: initial;
}

/** ----------------------------------------------------------------------------
 *                                                              Panel / Callout?
 */
.panel {
  background: rgba(51, 51, 51, 0.1019607843);
  border: solid 1px #9b9b9b;
  padding: 0.9em 1em;
}
.panel > :first-child {
  margin-top: 0;
}
.panel > :last-child {
  margin-bottom: 0;
}

/** ----------------------------------------------------------------------------
 *                                                              Scroll-triggered animations
 */
.scroll-triggered {
  transition: transform 0.5s, opacity 0.5s;
}
.scroll-triggered.slide-from-right {
  transform: translateX(200px);
  opacity: 0;
}
.scroll-triggered.active {
  transform: translateX(0);
  opacity: 1;
}

/** ----------------------------------------------------------------------------
 *                                                              Icons
 */
.icon.social {
  width: 24px;
}

/** ----------------------------------------------------------------------------
 *                                                              Search autocomplete
 */
.ui-autocomplete.ui-menu {
  overflow: auto;
}
.ui-autocomplete.ui-menu .ui-menu-divider {
  margin: 0;
}
.ui-autocomplete.ui-menu li {
  color: #4d4d4d;
  font-size: 0.85em;
}
.ui-autocomplete.ui-menu a {
  display: block;
}
.ui-autocomplete.ui-menu a:hover {
  background-color: rgba(0, 0, 0, 0.02);
}
.ui-autocomplete.ui-menu .ui-autocomplete-content .ui-autocomplete-field-group {
  background-color: rgba(35, 100, 166, 0.05);
  opacity: 100%;
  color: gray;
  font-size: 0.65em;
  padding: 0.3em 0.5em;
  text-transform: uppercase;
  font-weight: normal;
}
.ui-autocomplete.ui-menu .ui-autocomplete-content li > a {
  padding: 0.2em 0.5em;
}
.ui-autocomplete.ui-menu .ui-autocomplete-content li .ui-autocomplete-field-created {
  font-weight: normal;
  font-size: 0.8em;
  color: gray;
}
.ui-autocomplete.ui-menu .ui-autocomplete-content .ui-state-active {
  color: white;
  background: var(--colour-primary);
  border: transparent;
}
.ui-autocomplete.ui-menu .ui-autocomplete-content .ui-state-active a {
  text-decoration: inherit;
}
.ui-autocomplete.ui-menu .ui-autocomplete-content .ui-state-active .ui-autocomplete-field-title {
  font-weight: bold;
}
.ui-autocomplete.ui-menu .ui-autocomplete-content .ui-state-active .ui-autocomplete-field-created {
  color: white !important;
  opacity: 70%;
}
.ui-autocomplete.ui-menu .ui-autocomplete-container-more_results li {
  font-size: 0.65em;
  text-align: center;
}
.ui-autocomplete.ui-menu .ui-autocomplete-container-more_results a {
  color: #6e6e6e;
  display: block;
  padding: 0.5em 0.5em;
}
.ui-autocomplete.ui-menu .ui-autocomplete-container-more_results a div {
  display: inline;
}

/** ----------------------------------------------------------------------------
 *                                                              Node pages: Full view mode
 */
[data-view-mode=full] header {
  display: flex;
  gap: 2em;
  align-items: center;
  margin-bottom: 5%;
}
[data-view-mode=full] header * + .field {
  margin-top: 0.5em;
}
[data-view-mode=full] header figure .field {
  margin: 0;
}
[data-view-mode=full] header h1 {
  margin: 0;
}
[data-view-mode=full] header .field--name-field-subtitle {
  font-size: 1.5em;
}
[data-view-mode=full] header .field--name-field-media-image {
  margin-top: 0;
}
[data-view-mode=full] header figure {
  margin: 0;
  flex: 0 0 auto;
}
[data-view-mode=full] header img {
  width: 120px;
}
[data-view-mode=full] header .node__submitted {
  color: gray;
  font-size: 0.85em;
  margin-top: 0.5em;
}
[data-view-mode=full] header .node__submitted a {
  color: inherit;
}
[data-view-mode=full] header .field--name-field-author > div {
  display: inline;
}
[data-view-mode=full] h1 {
  text-align: initial;
}
[data-view-mode=full] .find-more,
[data-view-mode=full] .field--name-taxonomy-vocabulary-1 {
  padding-top: 1em;
  border-top: solid 1px #dbdbdb;
}
[data-view-mode=full] .find-more {
  font-style: italic;
}
[data-view-mode=full] .field--name-taxonomy-vocabulary-1 .field__label {
  font-size: 1.2em;
  margin-bottom: 0.5em;
}
[data-view-mode=full] .field--name-taxonomy-vocabulary-1 .field__items {
  display: flex;
  gap: 0.8em;
  flex-wrap: wrap;
}
[data-view-mode=full] .field--name-taxonomy-vocabulary-1 .field__items .field__item a {
  display: block;
  border: solid 1px #dbdbdb;
  border-radius: 6px;
  padding: 1em;
}

/** ----------------------------------------------------------------------------
 *                                                              Nodes: Smaller view modes
 */
.card .field--name-field-related-content,
.card .field--name-field-nodes .field__items {
  margin-top: 1em;
  display: flex;
  gap: 3px;
  flex-wrap: wrap;
}

[data-view-mode=inline] .node__content {
  width: 50px;
  height: 50px;
  background: #f0f0f0;
}
[data-view-mode=inline] .node__content img {
  aspect-ratio: 1/1;
  object-fit: cover;
}

[data-type=page][data-view-mode=full] {
  max-width: 40rem;
  margin-left: auto;
  margin-right: auto;
}
[data-type=page][data-view-mode=full] h1 {
  text-align: center;
}

article[data-view-mode=sidebar-card] {
  /*header {
    display: flex;
    gap: 1em;
    align-items: center;
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
    background: #f5f5f5;
    border-bottom: solid 1px #dfdfdf;
    margin-bottom: 0;

    & > * {
      flex: 1 1 auto;
    }
    figure {
      flex: 0 0 auto;
      width: 65px;
      margin: 0;

      img {
        border-top-left-radius: 8px;
      }
    }
    h3 {
      margin: 0;
      padding: 0.3em 0.5em 0.3em 0;
      font-size: 1.1em;
    }
  }*/
  /*.node__content {
    padding: 0.8em 1em;
  }*/
}

.pkgblock {
  background-color: white;
  border: solid 1px #d6d6d6;
  box-shadow: 0 1px 4px hsla(0, 0%, 0%, 0.1);
  margin-bottom: 0.5em;
  overflow: auto;
  padding: 0.9em;
}
.pkgblock .field {
  margin-top: 0;
  margin-bottom: 0;
}
.pkgblock .leftimage {
  width: 100px;
  float: left;
  margin: 0 1.5em 0.5em 0;
}
.pkgblock p:first-of-type {
  margin-top: 0;
}
.pkgblock p:last-child {
  margin-bottom: 0;
}

mjx-container {
  overflow-x: auto;
  position: static !important;
}

.pub_date {
  display: none;
}

/** ----------------------------------------------------------------------------
 *                                                              Advent calendars
 */
.advent img:hover,
#adventcal img:hover,
body[class*=-advent] .block-system-main-block img:hover {
  transition: 0.15s;
  transform: scale(1.3);
}

/**
 * @file
 * Variables
 */
/* 30em @ 16px font size */
/* 60em @ 16px font size */
/* 60em @ 16px font size */
/* 80em @ 16px font size */
:root {
  --header-stack-width: 850px;
  --site_max_width: 1200px;
  --text-max-width: 40rem;
  --header-height: 60px;
  --nav-height: 40px;
  --footer-height: 100px;
  --sidebar-width: 25%;
  /* used in width functions */
  --w-narrow: 480px;
  --w-regular: 960px;
  --w-average: 960px;
  --w-wide: 1200px;
  --gutter-narrow: 3vw;
  --gutter-regular: 5vw;
  --gutter-wide: 7vw;
  --site_padding-narrow: 5%;
  --pointer_target-padding: 0.6em 0.8em;
  --pointer_target-line-height: 1.3em; /* Assuming font-size: 1rem; */
  --data-field-padding: 0.5em 0.7em; /* used by table cells and text fields */
  --corner_radius-large: 8px;
  --corner_radius-regular: 5px;
  --corner_radius-small: 3px;
  --transition-duration-regular: 0.4s;
}

:root {
  --font-size: 1em;
  --line-height: 1.4;
  --font-size-h1: calc(1.5em + 1vw);
  --font-size-h1-max: 2em;
  --font-size-h2: calc(1.2em + 0.7vw);
  --font-size-h3: calc(1em + 0.5vw);
  --font-size-h4: calc(0.9em + 0.35vw);
  --font-size-h5: 0.83em;
  --font-size-h6: 0.67em;
  --line-height-h1: 1;
  --line-height-h2: 1.15;
  --line-height-h3: 1.3;
  --line-height-h4: 1.38;
  --line-height-h5: 1.45;
  --line-height-h6: 1.5;
}

:root {
  --font-sans: "Open Sans", sans-serif;
  --font-body: var(--font-sans);
  --font-headings: var(--font-body);
  --menu-case: initial;
  --font-weight-body: 400;
  --font-weight-links: 600;
}

:root {
  --colour-near_white: #f5f5f5;
  --colour-dark_grey: #444;
  --colour-medium_grey: #999;
  --colour-dividers: rgba(0, 0, 0, 0.2);
  --colour-selection: #40b6ff;
  --colour-danger: #c72100;
  --colour-error: #e62600;
  --colour-warning: #e09600;
  --colour-success: #77b259;
  --colour-unpublished: #CF5541;
  --colour-primary: #904091;
  /* Social media */
}

:root {
  --colour-secondary: var(--colour-medium_grey);
  --colour-primary-dark: var(--colour-primary);
  --colour-primary-light: var(--colour-primary);
  --colour-primary-lightest: var(--colour-primary);
  --colour-primary-pale: var(--colour-primary);
  --colour-bg-body: white;
  --colour-text-body: var(--colour-dark_grey);
  --colour-links: #2E6088;
  --colour-subtle: var(--colour-text-body);
  --colour-banner: var(--colour-primary-dark);
  --colour-bg-footer: var(--colour-dark_grey);
  --colour-text-footer: var(--colour-medium_grey);
}

/** ----------------------------------------------------------------------------
 *                              Basic pages
 */
/** ----------------------------------------------------------------------------
 *                              Landing pages
 */
.page-node-type-landing-page [id=body],
.page-node-type-landing-page [id=body] > * {
  max-width: 100% !important;
}
.page-node-type-landing-page [id=body] {
  margin-left: initial;
  margin-right: initial;
  width: initial;
  max-width: initial;
}

[data-type=landing-page][data-view-mode=full] > .node__content {
  margin-left: initial;
  margin-right: initial;
  width: initial;
  max-width: initial;
}
[data-type=landing-page][data-view-mode=full] > .node__content > .field--name-body > :not(.tex2jax_process), [data-type=landing-page][data-view-mode=full] > .node__content > .field--name-body > .tex2jax_process > * {
  margin-left: auto;
  margin-right: auto;
  width: 88%;
  max-width: 1200px;
}
[data-type=landing-page][data-view-mode=full] > .node__content > .field--name-body > .wp-block-group:not([class*=max-width]) {
  margin-left: initial;
  margin-right: initial;
  width: initial;
  max-width: initial;
}
[data-type=landing-page][data-view-mode=full] > .node__content > .field--name-body > .wp-block-group:not([class*=max-width]) > * {
  margin-left: auto;
  margin-right: auto;
  width: 88%;
  max-width: 1200px;
}
[data-type=landing-page][data-view-mode=full] .cta {
  max-width: initial !important;
  width: initial !important;
}

/** ----------------------------------------------------------------------------
 *                              Search pane
 */
.region-search-pane {
  max-width: var(--site_max_width);
  width: 90%;
  padding: 2.2em 2.4em;
  box-sizing: border-box;
  border-radius: 7px;
  border: none;
  box-shadow: 1px 1px 8px rgba(0, 0, 0, 0.25);
  margin-top: 10px;
  /*&.hidden,
  &[aria-hidden="true"] {
    display: none;
  }*/
  /*.view-topics,
  .view-tags {
    .view-content {
      columns: 3 15em;
      column-gap: 50px;

      & > div {
        overflow: auto;
        margin-bottom: 2em;
      }
    }
  }*/
}
.region-search-pane [id=block-search-form] {
  max-width: var(--text-max-width);
  margin-left: auto;
  margin-right: auto;
}
.region-search-pane button.close {
  margin: 0;
  top: 0;
  right: 0;
  position: absolute;
  background: none;
}
.region-search-pane a {
  font-weight: normal;
}
.region-search-pane h2 {
  text-align: center;
  font-size: 2em;
  margin-top: 2.5rem;
  margin-bottom: 2.5rem;
  font-weight: normal;
}
.region-search-pane h3 {
  margin-top: 0;
  font-size: 1.1em;
}
.region-search-pane ul {
  list-style-type: square;
}
.region-search-pane .block[id*=search-form] form {
  max-width: 100%;
}
.region-search-pane .block[id*=search-form] input[type=search] {
  width: 100%;
  border-color: #4b4b4b;
}
.region-search-pane [id=block-search-pane-tags] {
  font-size: 0.85em;
  line-height: 1.3;
}
.region-search-pane .ui-autocomplete.ui-menu {
  border-radius: 6px;
  border: solid 1px #535353;
  margin-top: 2px;
  box-shadow: 1px 1px 7px hsla(0, 0%, 0%, 0.28);
}

:root {
  --button-padding: var(--pointer_target-padding);
}

button.cookiesjsr-btn {
  cursor: pointer;
  font: inherit;
  width: auto;
  text-transform: none;
  padding: var(--button-padding);
  text-decoration: none;
  white-space: nowrap;
  margin: 0;
  opacity: 0.95;
  transform: scale(1);
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  color: var(--btn-font-color, #FFF);
  border: 1px solid var(--btn-border-color, #FFF);
  background-color: transparent;
}
button.cookiesjsr-btn:hover {
  opacity: 1;
  transform: scale(1.02);
}
button.cookiesjsr-btn.invert {
  color: var(--btn-inv-font-color, #292929);
  border-color: var(--btn-inv-border-color, #292929);
  background-color: var(--btn-inv-bg-color, #FFF);
}
button.cookiesjsr-btn.important {
  color: var(--btn-prime-font-color, #292929);
  border-color: var(--btn-prime-border-color, #FFF);
  background-color: var(--btn-prime-bg-color, #FFF);
}
button.cookiesjsr-btn.important.invert {
  color: var(--btn-prime-inv-font-color, #FFF);
  border-color: var(--btn-prime-inv-border-color, #292929);
  background-color: var(--btn-prime-inv-bg-color, #292929);
}

.cookiesjsr-links {
  margin: 0;
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
}
@media (min-width: 576px) {
  .cookiesjsr-links.links--row {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: left;
    align-items: center;
    gap: 1em;
  }
}
.cookiesjsr-links.links--row li {
  margin: 0;
  position: relative;
}
.cookiesjsr-links.links--row li a {
  margin: 0;
  padding: 0;
  font-weight: inherit;
  display: inline-block;
  text-decoration: underline;
  color: var(--link-list-font-color);
}
.cookiesjsr-links.links--row li:first-child:before {
  content: none;
}
@media (min-width: 576px) {
  .cookiesjsr-links.links--row li {
    /*&:before {
      content: '';
      position: absolute;
      top: 50%;
      left: 0;
      width: .3em;
      height: .3em;
      background-color: var(--link-list-separator-color, #FFF);
      transform: translate(-50%, -40%);
    }*/
  }
}

.cookiesjsr-btn.denyAll {
  display: none;
}
@media (min-width: 1200px) {
  .cookiesjsr-btn.denyAll {
    display: inline-block;
  }
}

.cookiesjsr-switch {
  position: relative;
  margin: 0;
  padding: 0;
  display: block;
  width: var(--switch-width, 45px);
  height: var(--switch-height, 20px);
  border-radius: var(--switch-height, 20px);
  background-color: var(--switch-bg-off, #FFF);
  cursor: pointer;
  box-shadow: inset -1px 2px 1px rgba(0, 0, 0, 0.25);
  border: 0;
  transition: background-color 0.1s ease-in-out;
}
.cookiesjsr-switch:focus-within:before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 10px;
  border: 1px dotted #eee;
  transform: scale(1.4);
}
.cookiesjsr-switch:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: var(--switch-height, 20px);
  height: var(--switch-height, 20px);
  border-radius: var(--switch-height, 20px);
  transform: scale(1.2);
  background-color: var(--switch-handle-color, #FFF);
  border: 1px solid var(--switch-border-color, #e4e5e6);
  transition: left 0.1s ease-in-out;
  box-shadow: -1px 2px 1px rgba(0, 0, 0, 0.25);
}
.cookiesjsr-switch.active {
  background-color: var(--switch-bg-on, #00AA00);
}
.cookiesjsr-switch.active:after {
  left: 25px;
}
.cookiesjsr-switch input[type=checkbox] {
  position: absolute;
  opacity: 0;
}

.cookiesjsr-banner {
  position: fixed;
  z-index: 10000;
  bottom: 0;
  width: 800px;
  max-width: 100%;
  height: auto;
  left: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: 14px;
  padding: 0.6em 1em;
  background-color: var(--banner-bg-color, #292929);
  border: solid 1px #4f4f4f;
  color: var(--banner-font-color, #FFF);
  max-height: calc(100vh - 100px);
  overflow: auto;
  transform: translateY(100%);
  transition: transform 0.3s ease-in-out;
}
@media (min-width: 800px) {
  .cookiesjsr-banner {
    left: calc(50% - 400px);
    border-radius: 4px;
  }
}
.cookiesjsr-banner.active {
  transform: translateY(0);
}
@media (min-width: 800px) {
  .cookiesjsr-banner.active {
    transform: translateY(-6px);
  }
}
@media (min-width: 768px) {
  .cookiesjsr-banner {
    flex-direction: row;
  }
}
.cookiesjsr-banner a {
  color: var(--link-list-font-color, #FFF);
}
.cookiesjsr-banner--info {
  flex-grow: 1;
}
.cookiesjsr-banner--text {
  display: block;
}
.cookiesjsr-banner--links {
  margin-top: 0.5em;
  font-size: 0.85em;
}
.cookiesjsr-banner--action {
  display: flex;
  padding: 0;
  gap: 10px;
}
@media (max-width: 360px) {
  .cookiesjsr-banner--action {
    flex-wrap: wrap;
  }
}
.cookiesjsr-banner button.denyAll {
  display: inline-block;
}

.cookiesjsr-service-groups {
  position: static !important;
  display: block;
  max-height: 100%;
  overflow: auto;
  list-style: none;
  margin: 0 0 -1px !important;
  padding: 0 !important;
  white-space: initial;
}

.cookiesjsr-service-group {
  position: static !important;
  line-height: 1.5;
  list-style: none;
  float: none !important;
  margin: 0 !important;
}
.cookiesjsr-service-group--tab {
  min-height: 3em;
  padding: 1em var(--default-margin, 1.25em);
  display: block;
  width: 100%;
  text-decoration: none;
  text-align: left;
  cursor: pointer;
  font-weight: 700;
  margin: 0;
  border: 0;
  border-radius: 0;
  color: var(--layer-tab-font-color, #000f37) !important;
  background: var(--layer-tab-bg-color, #FFF);
  border-bottom: 1px solid var(--layer-border-color, #e4e5e6);
  -webkit-appearance: none;
  -moz-appearance: none;
}
.cookiesjsr-service-group--tab:last-child {
  border-bottom: 0;
}
@media (min-width: 768px) {
  .cookiesjsr-service-group--tab {
    padding: 1em 3.25em 1em 1.25em;
    width: calc(30% + 2em);
  }
}
.cookiesjsr-service-group--content {
  display: none;
}
@media (min-width: 768px) {
  .cookiesjsr-service-group--content {
    position: absolute;
    width: 70%;
    height: 100%;
    overflow: auto;
    right: 0;
    top: 0;
  }
}
.cookiesjsr-service-group--intro {
  padding: 1em var(--default-margin, 1.25em);
}
.cookiesjsr-service-group.active .cookiesjsr-service-group--tab {
  color: var(--layer-tab-active-font-color, #FFF) !important;
  background: var(--layer-tab-active-bg-color, #292929);
  border-bottom: 0 none;
}
.cookiesjsr-service-group.active .cookiesjsr-service-group--content {
  display: block;
  color: var(--layer-tab-active-font-color, #FFF) !important;
  background: var(--layer-tab-active-bg-color, #292929);
  font-weight: 500;
}
.cookiesjsr-service-group--services {
  margin: 0 !important;
  padding: 0 !important;
}

.cookiesjsr-service {
  display: flex;
  align-items: center;
  background-color: rgba(228, 229, 230, 0);
  transition: background-color 0.3s ease;
}
.cookiesjsr-service:hover {
  background-color: rgba(228, 229, 230, 0.1);
}
.cookiesjsr-service--description {
  padding: 0.625em 1.25em;
  width: calc(100% - 2.5em - 45px);
}
.cookiesjsr-service--description h3 {
  margin: 0;
  font-size: 1.125em;
  font-weight: 400;
  color: var(--layer-font-light, #FFF);
}
.cookiesjsr-service--links a {
  color: var(--layer-font-light, #FFF);
  font-size: 0.75em;
}
.cookiesjsr-service--links a:hover, .cookiesjsr-service--links a:active, .cookiesjsr-service--links a:visited {
  color: var(--layer-font-light, #FFF);
}
.cookiesjsr-service--action {
  padding: 0.625em 1.25em;
  width: calc(2.5em + 45px);
}
.cookiesjsr-service--always-on {
  color: var(--switch-always-on-font-color, #00AA00);
  text-align: right;
  display: flex;
  justify-content: flex-end;
  white-space: nowrap;
}
.cookiesjsr-service--always-on span {
  background-color: var(--switch-always-on-bg-color, #FFF);
  padding: 0 0.5em;
}

.cookiesjsr-layer {
  display: block;
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background: var(--layer-header-bg-color, #FFF);
  height: 100vh;
  width: 100vw;
  max-width: 100%;
  z-index: 314160;
  padding: var(--layer-header-height, 3.5em) 0 var(--layer-footer-height, 4.5em);
  overflow: hidden;
  line-height: 1.5;
}
@media (min-height: 668px) {
  .cookiesjsr-layer {
    height: 80vh;
    max-height: 575px;
  }
}
@media (min-height: 992px) {
  .cookiesjsr-layer {
    height: 60vh;
  }
}
@media (min-width: 768px) {
  .cookiesjsr-layer {
    width: 860px;
  }
}
.cookiesjsr-layer--overlay {
  position: fixed;
  z-index: 314159;
  height: 100vh;
  width: 100vw;
  left: 0;
  top: 0;
  background: rgba(0, 0, 0, 0.4);
}
.cookiesjsr-layer--header {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 100;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: #FFF;
  margin: 0;
  background: var(--layer-header-bg-color, #FFF);
  padding: 0 var(--default-margin, 1.25em);
  border-bottom: 1px solid var(--layer-border-color, #e4e5e6);
  height: 3.5em;
}
.cookiesjsr-layer--title {
  color: var(--layer-header-font-color, #000f37);
  text-transform: uppercase;
}
.cookiesjsr-layer--close {
  z-index: 102;
  width: 1em;
  height: 1em;
  background: transparent url("data:image/svg+xml,%0A%3Csvg width='27px' height='27px' viewBox='0 0 27 27' version='1.1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink'%3E%3Cg id='Welcome' stroke='none' stroke-width='1' fill='none' fill-rule='evenodd'%3E%3Cg id='tarte-close' transform='translate(-1264.000000, -2628.000000)' fill='%23000f37'%3E%3Cg id='Group-2' transform='translate(155.000000, 2591.000000)'%3E%3Cg id='Group-3-Copy-2'%3E%3Cpolygon id='Page-1' points='1133.26296 37 1122.50065 47.762319 1111.73704 37 1109 39.7370358 1119.76361 50.5006452 1109 61.2629642 1111.73704 64 1122.50065 53.2363906 1133.26296 64 1136 61.2629642 1125.23768 50.5006452 1136 39.7370358'%3E%3C/polygon%3E%3C/g%3E%3C/g%3E%3C/g%3E%3C/g%3E%3C/svg%3E") no-repeat center center scroll;
  background-size: contain;
  text-indent: -999em;
  overflow: hidden;
  border: 0;
  cursor: pointer;
  padding: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
}
.cookiesjsr-layer--body {
  position: absolute;
  left: 0;
  right: 0;
  background: var(--layer-body-bg-color, #FFF);
  top: var(--layer-header-height, 3.5em);
  bottom: var(--layer-footer-height, 4.5em);
}
.cookiesjsr-layer--footer {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 0 var(--default-margin, 1.25em);
  height: var(--layer-footer-height, 4.5em);
  display: flex;
  justify-content: flex-end;
  align-items: center;
  background: var(--layer-footer-bg-color, #FFF);
  border-top: 1px solid var(--layer-border-color, #e4e5e6);
}
@media (min-width: 768px) {
  .cookiesjsr-layer--footer {
    justify-content: space-between;
  }
}
.cookiesjsr-layer--label-all {
  color: var(--layer-footer-font-color, #000f37);
  display: none;
}
@media (min-width: 768px) {
  .cookiesjsr-layer--label-all {
    display: block;
    width: 30%;
    padding-right: var(--default-margin, 1.25em);
  }
}
.cookiesjsr-layer--actions {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 0 -0.625em;
  width: calc(100% + 1.25em);
}
@media (min-width: 768px) {
  .cookiesjsr-layer--actions {
    width: calc(70% + 0.625em);
  }
}
.cookiesjsr-layer button.denyAll, .cookiesjsr-layer button.allowAll {
  display: none;
}
@media (min-width: 576px) {
  .cookiesjsr-layer button.denyAll, .cookiesjsr-layer button.allowAll {
    display: inline-block;
  }
}
@media (max-width: 576px) {
  .cookiesjsr-layer button.save {
    padding: 0 2em;
    width: auto;
    margin-left: auto;
  }
}

#cookiesjsr {
  --default-margin: 1.25em;
  --font-size-reset: 1rem;
  --btn-font-color: #FFF;
  --btn-border-color: #FFF;
  --btn-bg-color: #292929;
  --btn-prime-font-color: #292929;
  --btn-prime-border-color: #FFF;
  --btn-prime-bg-color: #FFF;
  --btn-inv-font-color: #292929;
  --btn-inv-border-color: #292929;
  --btn-inv-bg-color: #FFF;
  --btn-prime-inv-font-color: #FFF;
  --btn-prime-inv-border-color: #292929;
  --btn-prime-inv-bg-color: #292929;
  --link-list-font-color: hsla(0, 0%, 100%, 0.7); /*#FFF;*/
  --link-list-separator-color: #FFF;
  --banner-logo-offset: 100px;
  --banner-bg-color: #292929;
  --banner-font-color: #FFF;
  --layer-header-height: 3.5em;
  --layer-header-bg-color: #FFF;
  --layer-header-font-color: #000f37;
  --layer-body-bg-color: #FFF;
  --layer-tab-bg-color: #FFF;
  --layer-tab-font-color: #000f37;
  --layer-tab-active-bg-color: #292929;
  --layer-tab-active-font-color: #FFF;
  --layer-bg-dark: #292929;
  --layer-font-light: #FFF;
  --layer-font-dark: #000f37;
  --layer-border-color: #e4e5e6;
  --layer-footer-bg-color: #FFF;
  --layer-footer-font-color: #000f37;
  --layer-footer-height: 4.5em;
  --switch-border-color: #e4e5e6;
  --switch-handle-color: #FFF;
  --switch-bg-off: #FFF;
  --switch-bg-on: #00AA00;
  --switch-width: 45px;
  --switch-height: 20px;
  --switch-always-on-font-color: #00AA00;
  --switch-always-on-bg-color: #FFF;
}

.cookiesjsr--app {
  font-size: var(--font-size-reset, 1rem);
}

body .cookiesjsr--app,
body .cookiesjsr--app *, body .cookiesjsr--app *:before, body .cookiesjsr--app *:after {
  box-sizing: border-box;
}

/**
 * Overrides for system blocks like the Contact form block.
 */
.contact-message-form {
  background: var(--colour-primary-pale);
  padding: 1.4em 1.5em;
  box-sizing: border-box;
}
.contact-message-form > h2 {
  margin-top: 0;
}

header[role=banner] input[type=search],
[id=nav-container] input[type=search] {
  border-radius: 2em;
  padding: 0.6em 0.6em 0.6em 40px;
  background-position: 9px 50% !important;
  width: 280px;
}

header[role=banner] {
  position: relative;
  box-sizing: border-box;
  /*nav .menu {
    margin: 0;
    //display: inline-block;
    display: flex;
    gap: 0.5em;

    li {
      position: relative;
      flex: 1 1 auto;
    }

    @media all and (min-width: $header-stack-width) {
     height: 100%;
      align-items: center;
      max-width: none;

      & > * {
      	flex: 1;
      }
    }
  }*/
}
header[role=banner]:after {
  content: "";
  display: table;
  clear: both;
}
header[role=banner] .region {
  background: var(--colour-primary);
  box-sizing: border-box;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.8em;
}
@media (min-width: 850px) {
  header[role=banner] .region {
    margin-left: auto;
    margin-right: auto;
    width: 88%;
    max-width: 1200px;
    background: none;
  }
}
header[role=banner] .region > * {
  flex: 0 1 auto;
  vertical-align: middle;
}
@media (max-width: 850px) {
  header[role=banner] .region > * {
    display: block;
    text-align: center !important;
  }
}
header[role=banner] .block[id$=branding] {
  display: flex;
  align-items: center;
  gap: 1em;
}
header[role=banner] .site-logo {
  max-width: 200px;
}
@media only screen and (max-width: 850px) {
  header[role=banner] .site-logo {
    height: var(--header-height);
  }
}
header[role=banner] .site-logo > * {
  flex: 1;
}
@media only screen and (min-width: 680px) {
  header[role=banner] .site-logo {
    width: auto;
  }
}
header[role=banner] .site-logo a {
  color: inherit;
  text-decoration: none;
}
header[role=banner] .site-logo h1 {
  font-size: 3.5em;
  margin: 0;
  color: #fff;
  line-height: 1em;
  text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.3);
}
header[role=banner] .site-logo img {
  max-width: 100%;
}
@media (min-width: 380px) {
  header[role=banner] .site-logo img {
    max-width: 180px;
    max-height: calc(100% - 26px);
  }
}
@media (min-width: 850px) {
  header[role=banner] .site-logo img {
    max-width: 260px;
    margin: 13px 0;
  }
}
header[role=banner] .site-name {
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}
header[role=banner] .block[id$=branding],
header[role=banner] .branding_block {
  gap: 0 !important;
}
header[role=banner] .block-title {
  display: none;
}
header[role=banner] .block[id*=menutoggle] {
  flex-shrink: 0;
  padding-right: 20px;
  padding-left: 20px;
  background: #2e2e2e;
  align-self: stretch;
  display: flex;
  align-items: center;
}
@media all and (min-width: 850px) {
  header[role=banner] .block[id*=menutoggle] {
    display: none;
  }
}
header[role=banner] .block[id*=menutoggle] button {
  margin: 0;
  background: none;
}

/** ----------------------------------------------------------------------------
 *                              CONTENTS
  Navigation
  Mobile navigation
  Main
  Sidebar
  Comments
 */
/** ----------------------------------------------------------------------------
 *                              Navigation
 */
[id=primary-nav],
.region-mobile-nav {
  background: #2e2e2e;
  color: white;
}
[id=primary-nav] a,
.region-mobile-nav a {
  color: inherit;
}
[id=primary-nav] a:hover, [id=primary-nav] a:focus,
.region-mobile-nav a:hover,
.region-mobile-nav a:focus {
  color: inherit;
}

[id=primary-nav] {
  min-height: 1px;
}
[id=primary-nav] .region {
  display: flex;
  justify-content: space-between;
}
[id=primary-nav] .block {
  display: flex;
  align-items: center;
}
[id=primary-nav] .block[role=search] form {
  margin: 0;
}
[id=primary-nav] .block-menu menu li > :is(a, button, span),
[id=primary-nav] .block-menu .menu li > :is(a, button, span) {
  padding: 1em 1em;
  border-radius: 6px;
}
[id=primary-nav] .block-menu menu li > a::before,
[id=primary-nav] .block-menu .menu li > a::before {
  content: "";
  position: absolute;
  inset: 0;
}
[id=primary-nav] .block-menu menu menu li > :is(a, button, span),
[id=primary-nav] .block-menu .menu menu li > :is(a, button, span) {
  padding: 0.4em 0.7em;
}
[id=primary-nav] h2 {
  color: inherit;
  font-size: 1em;
  font-weight: initial;
  opacity: 60%;
  align-self: flex-end;
  margin: 0;
  padding: 0.5em;
}
[id=primary-nav] input[type=submit] {
  margin: 0;
}

/** ----------------------------------------------------------------------------
 *                              Mobile navigation
 */
.region .block[id*=phonemenubutton] {
  display: flex;
  align-items: center;
}
@media all and (min-width: 850px) {
  .region .block[id*=phonemenubutton] {
    display: none;
  }
}
.region .block[id*=phonemenubutton] button {
  display: inline-block;
  padding: 0.6em 0.8em;
  background: none;
  color: var(--colour-links);
  margin: 0;
}

[id=mobile-nav] .slide-in {
  margin-top: 50px;
}

.region-mobile-nav {
  --h-padding: 10px;
  padding-top: var(--h-padding);
  padding-bottom: var(--h-padding);
}
.region-mobile-nav .block {
  padding-left: var(--h-padding);
  padding-right: var(--h-padding);
}
.region-mobile-nav .block-menu {
  padding-left: 0;
  padding-right: 0;
}
.region-mobile-nav .field {
  margin-top: 0;
  margin-bottom: 0;
}
.region-mobile-nav menu,
.region-mobile-nav .menu {
  padding: 0;
  margin: 0 !important;
}
.region-mobile-nav menu li > :is(a, button, span),
.region-mobile-nav .menu li > :is(a, button, span) {
  padding: 0.6em var(--h-padding);
}
.region-mobile-nav menu li > button,
.region-mobile-nav .menu li > button {
  display: flex !important;
  gap: 0.2em;
}
.region-mobile-nav menu li > button > span,
.region-mobile-nav .menu li > button > span {
  flex-grow: 1;
}
.region-mobile-nav menu li button,
.region-mobile-nav .menu li button {
  display: block;
  flex-grow: 1;
  text-align: left;
}
.region-mobile-nav menu img,
.region-mobile-nav .menu img {
  margin-left: 6px;
}
.region-mobile-nav menu > *,
.region-mobile-nav .menu > * {
  display: block !important;
}
.region-mobile-nav menu > * > li,
.region-mobile-nav menu > * menu.dropdown,
.region-mobile-nav .menu > * > li,
.region-mobile-nav .menu > * menu.dropdown {
  position: relative;
  padding: 0.4em 0 0.4em 0.6em;
  background: rgba(0, 0, 0, 0.2);
  width: 100%;
  max-width: initial;
}
.region-mobile-nav menu > * > li > :is(a, span),
.region-mobile-nav menu > * menu.dropdown > :is(a, span),
.region-mobile-nav .menu > * > li > :is(a, span),
.region-mobile-nav .menu > * menu.dropdown > :is(a, span) {
  border-width: 0 2px;
}
.region-mobile-nav menu > * > li > a.is-active,
.region-mobile-nav menu > * menu.dropdown > a.is-active,
.region-mobile-nav .menu > * > li > a.is-active,
.region-mobile-nav .menu > * menu.dropdown > a.is-active {
  border-left-color: var(--colour-text-body);
}
.region-mobile-nav menu > * > li > a:hover, .region-mobile-nav menu > * > li > a:focus,
.region-mobile-nav menu > * menu.dropdown > a:hover,
.region-mobile-nav menu > * menu.dropdown > a:focus,
.region-mobile-nav .menu > * > li > a:hover,
.region-mobile-nav .menu > * > li > a:focus,
.region-mobile-nav .menu > * menu.dropdown > a:hover,
.region-mobile-nav .menu > * menu.dropdown > a:focus {
  border-left-color: rgba(var(--colour-text-body), 0.3);
}
.region-mobile-nav menu > * > li.expanded ul,
.region-mobile-nav menu > * menu.dropdown.expanded ul,
.region-mobile-nav .menu > * > li.expanded ul,
.region-mobile-nav .menu > * menu.dropdown.expanded ul {
  display: block;
}
.region-mobile-nav .block-menu + .block-menu {
  border-top: solid 1px hsla(0, 0%, 90.2%, 0.11);
}
.region-mobile-nav > .block > h2 {
  display: none;
}
.region-mobile-nav form[id*=search] {
  display: flex;
  gap: 5px;
}
.region-mobile-nav form[id*=search] input[type=search] {
  width: 100%;
  margin-bottom: 0;
  border: none;
}
.region-mobile-nav form[id*=search] button {
  margin: 0;
}

/** ----------------------------------------------------------------------------
 *                              Main
*/
.page-content {
  padding-top: 3em;
  padding-bottom: 3em;
}

main .field-name-body h2, main .field-name-body h3 {
  clear: both;
}
main .subtitle {
  margin-bottom: 20px;
  font-style: italic;
}
main li {
  padding-left: 0.5em;
  line-height: 1.3em;
}
.block-local-tasks-block {
  margin-bottom: 1em;
}

/** ----------------------------------------------------------------------------
 *                              Sidebar
*/
aside .region {
  background: #eff5f5;
  padding: 2em 1.7em;
  box-sizing: border-box;
}
@media all and (min-width: 800px) {
  aside .region {
    border-radius: 4px;
  }
}
aside h2 {
  font-size: 1.15em;
}
aside h3 {
  font-size: 1.05em;
}
aside h4 {
  font-size: 0.95em;
}
aside :first-child > h2 {
  margin-top: 0;
}

.view-featured-author {
  text-align: center;
  margin-bottom: 32px;
}
.view-featured-author h3 {
  margin-top: 0.7em;
}
.view-featured-author img {
  border-radius: 50%;
  width: 140px;
}

footer[role=contentinfo] {
  background: #2e2e2e;
  color: white;
  padding: 2em 0;
  font-size: 0.85em;
}
footer[role=contentinfo] a {
  color: inherit;
}
footer[role=contentinfo] a:hover, footer[role=contentinfo] a:focus {
  color: inherit;
}
footer[role=contentinfo]::after {
  clear: both;
}
footer[role=contentinfo]::after:after {
  content: "";
  display: table;
  clear: both;
}
footer[role=contentinfo] img {
  max-width: 180px;
}
@media all and (min-width: 700px) {
  footer[role=contentinfo] .region {
    display: flex;
    margin: 0 auto;
  }
  footer[role=contentinfo] .region > * {
    flex: 1 1 0;
  }
  footer[role=contentinfo] .region > *:not(:first-child) {
    margin-left: calc(20px + 3vw);
  }
}
footer[role=contentinfo] .block {
  box-sizing: border-box;
}
footer[role=contentinfo] .block:first-child {
  padding-left: 0;
}
footer[role=contentinfo] .block:last-child {
  padding-right: 0;
}
footer[role=contentinfo] .center:after {
  content: "";
  display: table;
  clear: both;
}
footer[role=contentinfo] h2 {
  border-bottom: solid 1px #b0b0b0;
  padding-bottom: 0.2em;
  font-size: 1.1em;
  text-transform: uppercase;
}
footer[role=contentinfo] ul, footer[role=contentinfo] #footer #footer li {
  list-style: none;
}
footer[role=contentinfo] .prefix {
  width: 2em;
}
footer[role=contentinfo] form .form-item {
  margin: 0.5em 0;
}
footer[role=contentinfo] form input[type=text],
footer[role=contentinfo] form textarea {
  width: 100% !important;
  border: 1px solid #555;
  color: inherit;
  background: #333;
  box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.4) inset;
}
footer[role=contentinfo] form input[type=text]:focus,
footer[role=contentinfo] form textarea:focus {
  border: 1px solid #888;
}
footer[role=contentinfo] form textarea {
  height: 5em;
  min-height: 3.2em;
}
footer[role=contentinfo] .menu a:hover {
  color: var(--colour-links);
  background-color: rgba(0, 0, 0, 0.15);
}

[id=post-footer] {
  --colour-links: white;
  background-color: #0d0d0d;
  color: white;
  padding-top: 10px;
  padding-bottom: 10px;
  font-size: 0.8em;
}
[id=post-footer] a {
  color: inherit;
}
[id=post-footer] a:hover, [id=post-footer] a:focus {
  color: inherit;
}
[id=post-footer] p {
  margin: 0;
}
[id=post-footer] .region-post-footer {
  display: flex;
  justify-content: space-between;
  gap: 1em;
}
/*----------------------------------------------------------------------------
                                            Home (front)
*/
body.full-path--home [id=body],
body.full-path--content-home [id=body] {
  margin-top: 0;
}
body.full-path--home .block > h2,
body.full-path--content-home .block > h2 {
  text-align: center;
}
body.full-path--home .block[class*=carousel],
body.full-path--content-home .block[class*=carousel] {
  margin-bottom: 0 !important;
}
body.full-path--home .field--name-body > .block:first-child,
body.full-path--content-home .field--name-body > .block:first-child {
  margin-top: 0 !important;
}
body.full-path--home .between-sections + *,
body.full-path--content-home .between-sections + * {
  margin-top: calc(1em + 2vw + 40px) !important;
}

.block[class*=home-slides-carousel] {
  max-width: 1800px !important;
}

.view-home-slides-carousel .splide__slide {
  align-items: center;
}
.view-home-slides-carousel .splide__slide .field--name-field-media-image, .view-home-slides-carousel .splide__slide .field--name-field-media-image span, .view-home-slides-carousel .splide__slide .field--name-field-media-image div, .view-home-slides-carousel .splide__slide .field--name-field-media-image img {
  display: block;
  height: 100%;
}
.view-home-slides-carousel .splide__slide .overlay {
  margin: 0;
  justify-self: flex-end;
  width: 16em;
  background: rgba(255, 255, 255, 0.7411764706);
  box-shadow: 1px 1px 7px rgba(0, 0, 0, 0.1294117647);
  border-radius: 6px 0 0 6px;
  max-height: 70%;
  overflow: auto;
}
@media (min-width: 500px) {
  .view-home-slides-carousel .splide__slide .overlay {
    margin-right: 6%;
    border-radius: 6px;
  }
}

/*----------------------------------------------------------------------------
                                           Login / Reset password
*/
body.path-user form[id=user-login-form],
body.path-user form[id=user-pass] {
  max-width: 24em;
}
body.path-user form[id=user-login-form] input[type=text],
body.path-user form[id=user-login-form] input[type=password],
body.path-user form[id=user-pass] input[type=text],
body.path-user form[id=user-pass] input[type=password] {
  display: block;
}

/*----------------------------------------------------------------------------
                                           Login / Reset password
*/
body.maintenance-page .layout-container {
  display: block;
  min-height: initial;
  margin-left: auto;
  margin-right: auto;
  width: 88%;
  max-width: 1200px;
  text-align: center;
  margin-top: 3vw;
}

/**
 * @file
 * Print styling
 */
/**
 * By importing this CSS file as media "all", we allow this print file to be
 * aggregated with other stylesheets, for improved path-frontpage-end performance.
 */
@media print {
  /* Underline all links. */
  a:link,
  a:visited {
    text-decoration: underline !important;
    /* Don't underline header. */
  }
  a:link.header__site-link,
  a:visited.header__site-link {
    text-decoration: none !important;
  }
  #content {
    /* Add visible URL after links. */
    /* Only display useful links. */
    /* Add visible title after abbreviations. */
  }
  #content a[href]:after {
    content: " (" attr(href) ")";
    font-weight: normal;
    font-size: inherit;
  }
  #content a[href^="javascript:"]:after,
  #content a[href^="#"]:after {
    content: "";
  }
  #content abbr[title]:after {
    content: " (" attr(title) ")";
  }
  /* Un-float the content. */
  #content {
    float: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  /* Turn off any background colors or images. */
  body,
  #page,
  #main,
  #content {
    color: #000;
    background-color: transparent !important;
    background-image: none !important;
  }
  /* Hide sidebars and nav elements. */
  #skip-link,
  #toolbar,
  #navigation,
  .region-sidebar-first,
  .region-sidebar-second,
  #footer,
  .breadcrumb,
  .tabs,
  .action-links,
  .links,
  .book-navigation,
  .forum-topic-navigation,
  .pager,
  .feed-icons {
    visibility: hidden;
    display: none;
  }
}

/*# sourceMappingURL=plus2025.css.map */
