:root {
  /* --primary:{{ branding.primary }}; */
  /* --primary:#DE2A29;
  --secondary:#385f58; */
  /* --dark:#333;
  --light:#f6f6f6;
  --grey:#888;
  --white:#fff */
}


@import url("https://p.typekit.net/p.css?s=1&k=fwx4wxp&ht=tk&f=10888.40486.40488.40492&a=3970345&app=typekit&e=css");

@font-face {
  font-family: "futura-pt";
  src: url("https://use.typekit.net/af/648f69/000000000000000000010098/27/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=i8&v=3") format("woff2"), url("https://use.typekit.net/af/648f69/000000000000000000010098/27/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=i8&v=3") format("woff"), url("https://use.typekit.net/af/648f69/000000000000000000010098/27/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=i8&v=3") format("opentype");
  font-display: auto;
  font-style: normal;
  font-weight: 800;
}

@font-face {
  font-family: "nunito-sans";
  src: url("https://use.typekit.net/af/7ac87a/00000000000000007735b8f0/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n3&v=3") format("woff2"), url("https://use.typekit.net/af/7ac87a/00000000000000007735b8f0/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n3&v=3") format("woff"), url("https://use.typekit.net/af/7ac87a/00000000000000007735b8f0/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n3&v=3") format("opentype");
  font-display: auto;
  font-style: normal;
  font-weight: 300;
}

@font-face {
  font-family: "nunito-sans";
  src: url("https://use.typekit.net/af/42930b/00000000000000007735b8f6/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff2"), url("https://use.typekit.net/af/42930b/00000000000000007735b8f6/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff"), url("https://use.typekit.net/af/42930b/00000000000000007735b8f6/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("opentype");
  font-display: auto;
  font-style: normal;
  font-weight: 400;
}

@font-face {
  font-family: "nunito-sans";
  src: url("https://use.typekit.net/af/ff2f63/00000000000000007735b8ff/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n7&v=3") format("woff2"), url("https://use.typekit.net/af/ff2f63/00000000000000007735b8ff/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n7&v=3") format("woff"), url("https://use.typekit.net/af/ff2f63/00000000000000007735b8ff/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n7&v=3") format("opentype");
  font-display: auto;
  font-style: bold;
  font-weight: 700;
}

@font-face {
  font-family: "nunito-sans";
  src: url("https://use.typekit.net/af/ff2f63/00000000000000007735b8ff/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n8&v=3") format("woff2"), url("https://use.typekit.net/af/ff2f63/00000000000000007735b8ff/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n8&v=3") format("woff"), url("https://use.typekit.net/af/ff2f63/00000000000000007735b8ff/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n8&v=3") format("opentype");
  font-display: auto;
  font-style: bold;
  font-weight: 800;
}

.tk-futura-pt {
  font-family: "futura-pt", sans-serif;
}

.tk-nunito-sans {
  font-family: "nunito-sans", sans-serif;
}


@font-face {
  font-family: 'icomoon';
  src: url("../fonts/icomoon.9351c76d7b02.eot?y1y6v");
  src: url("../fonts/icomoon.9351c76d7b02.eot?y1y6v#iefix") format('embedded-opentype'),
    url("../fonts/icomoon.e97800806911.woff2?y1y6v") format('woff2'),
    url("../fonts/icomoon.cc5db74230bd.ttf?y1y6v") format('truetype'),
    url("../fonts/icomoon.9f2ea8ec2e46.woff?y1y6v") format('woff'),
    url("../fonts/icomoon.d9c73acf709f.svg?y1y6v#icomoon") format('svg');
  font-weight: normal;
  font-style: normal;
  font-display: block;
}

[class^="icon-"],
[class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;

  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-epost:before {
  content: "\e91b";
}

.icon-telefon:before {
  content: "\e91c";
}

.icon-youtube:before {
  content: "\e918";
}

.icon-instagram:before {
  content: "\e919";
}

.icon-facebook:before {
  content: "\e91a";
}

.icon-elevside:before {
  content: "\e910";
}

.icon-kontakt:before {
  content: "\e911";
}

.icon-ansatte:before {
  content: "\e912";
}

.icon-klasser:before {
  content: "\e913";
}

.icon-priser:before {
  content: "\e914";
}

.icon-kurs:before {
  content: "\e916";
}

.icon-opplaering:before {
  content: "\e917";
}

.icon-ikon-be:before {
  content: "\e90c";
}

.icon-klasse-b:before {
  content: "\e90b";
}

.icon-klasse-ce2:before {
  content: "\e200c";
}

.icon-klasse-c1:before {
  content: "\e900";
}

.icon-klasse-d1e:before {
  content: "\e901";
}

.icon-klasse-a:before {
  content: "\e902";
}

.icon-klasse-a2:before {
  content: "\e903";
}

.icon-klasse-a1:before {
  content: "\e904";
}

.icon-klasse-m:before {
  content: "\e905";
}

.icon-klasse-t:before {
  content: "\e906";
}

.icon-klasse-de:before {
  content: "\e907";
}

.icon-klasse-d:before {
  content: "\e908";
}

.icon-klasse-d1:before {
  content: "\e909";
}

.icon-klasse-c:before {
  content: "\e90a";
}

.icon-klasse-c1e:before {
  content: "\e90e";
}

.icon-klasse-b96:before {
  content: "\e90f";
}

.icon-klasse-be:before {
  content: "\e90d";
}

.icon-klasse-ce:before {
  content: "\e915";
}


html {
  font-family: "nunito-sans";
  font-weight: 300;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  color: rgba(26, 26, 26, .8);
  fill: rgba(26, 26, 26, .8);
  font-size: 18px;
  font-weight: 300;
  line-height: 1.45em
}

body,
p {
  margin: 0
}

article,
aside,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary,
hr {
  display: block;
  margin: 0;
  padding: 0
}

figcaption,
address {
  font-style: normal
}

a {
  background-color: transparent;
  text-decoration: none
}

a {
  color: var(--secondary)
}

.opacity {
  opacity: .54
}

a:link,
a:active,
a:hover {
  outline: 0
}

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

h1,
.h1,
.h1-large,
h2,
.h2,
h3,
.h3,
h4,
.h4 {
  font-family: "futura-pt";
  font-weight: 800;
  margin: 0;
  font-style: normal;
}

h1,
.h1 {
  font-size: 3em;
  line-height: 1.15em
}

h2,
.h2 {
  font-size: 1.5em;
  line-height: 1.3em
}

h3,
.h3 {
  font-size: 1.25em
}

h4,
.h4 {
  font-size: 1.15em
}

b,
strong,
.strong {
  font-weight: 700
}

p,
figure {
  margin-bottom: 2em
}

small {
  font-size: 80%
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline
}

sup {
  top: -.5em
}

sub {
  bottom: -.25em
}

img {
  border: 0
}

svg#anon .st0 {
  fill: var(--light);
}

svg#anon .st1 {
  fill: var(--primary);
}

svg#anon .st2 {
  fill: #244540;
}

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

.max-h-60 {
  max-height: 60px
}

.min-h-120 {
  min-height: 120px
}

.w-auto {
  width: auto;
}

.img-auto-60 {
  width: 60%;
  height: auto
}

img[alt] {
  color: rgba(0, 0, 0, 0)
}

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

.fill-primary {
  fill: var(--primary)
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
  box-sizing: border-box
}

.block {
  display: block
}

.inline-block {
  display: inline-block
}

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

td,
th {
  padding: 0
}

.h-1em {
  height: 1em;
}

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

blockquote {
  margin: 0
}

blockquote p {
  border-left: .4em solid #c8d643;
  padding-left: .6em;
  font-style: italic;
  margin: 0;
  padding-bottom: .1em;
  padding-top: .1em
}

cite {
  text-align: right;
  display: block
}

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

.vFull {
  min-height: calc(100vh - 327px);
}

/* Wagtail styles */
.object-contain {
  object-fit: contain;
}

.responsive-object {
  position: relative;
  margin-bottom: 2em
}

.responsive-object iframe,
.responsive-object object,
.responsive-object embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

form p {
  margin: 0;
}

form label:not(.radio) {
  font-weight: bold;
  font-size: .8em;
}

form label.radio {
  cursor: pointer
}

.fancy-hover:hover>a>div {
  box-shadow: 4px 4px 8px rgb(0 0 0 / 30%);
}

.max-60 {
  max-width: 75%;
}

.bottom-line {
  border-bottom: 1px solid rgb(0 0 0 / 10%);
}

/* End Wagtail styles */
/* Custom styles */
.alert {
  padding: 20px;
  margin-bottom: 20px;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5);
  background-color: #fcf8e3;
  border: 1px solid #fbeed5;
  -webkit-border-radius: 4px;
  -moz-border-radius: 4px;
  border-radius: 4px;
  color: #c09853;
  font-family: monospace;
}

.alert-success {
  background-color: #dff0d8;
  border-color: #d6e9c6;
  color: #468847
}

.alert-error {
  background-color: #f2dede;
  border-color: #eed3d7;
  color: #b94a48
}

.alert-info {
  background-color: #d9edf7;
  border-color: #bce8f1;
  color: #3a87ad
}

table caption {
  text-align: left;
  text-transform: uppercase;
  font-family: "brother-1816-extended", sans-serif;
  font-weight: 500;
  padding-bottom: 10px;
  font-size: 1.1rem;
}

.title:after,
table caption:after {
  content: "";
  display: block;
  height: 4px;
  background: var(--primary);
  max-width: 80px;
  margin-top: .5em;
  margin-bottom: 1em;
}

.txt-center.title:after {
  margin-left: auto;
  margin-right: auto;
}

p:empty {
  display: none
}

.logo-top {
  width: 300px;
  height: auto
}

.logo-footer {
  width: 230px;
  height: auto;
}

.footer-lh-2 {
  line-height: 2em;
}

.footer-icon {
  font-size: 2em;
}

#navTop li.nav-menu-item {
  border-left: solid 1px var(--primary);
  border-right: solid 1px var(--primary);
}

#navTop li.nav-menu-item~li {
  border-left: none;
}

#navTop a {
  color: var(--secondary);
  font-size: .75em;
  font-weight: bold
}

#navTop a:hover {
  color: var(--primary)
}

#navTop .c2a {
  position: relative;
  top: 5px
}

#navTop li {
  min-width: 80px;
  font-size: .9em
}

#gallery a:hover img {
  opacity: .8
}

input[type="text"],
input[type="number"],
input[type="tel"],
input[type="email"],
textarea {
  font-size: .9em;
  background: #fff;
  width: 100%;
  height: 2.5em;
  line-height: 3em;
  padding: 0 1em;
  box-sizing: border-box;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 2px;
  border: 1px solid #ddd;
  outline: 0
}

input[type="checkbox"] {
  z-index: -1;
  opacity: 0
}

.not-hidden input[type="checkbox"] {
  z-index: 0;
  opacity: 1;
  width: 1.2rem;
  height: 1.2rem;
}

.btn-disabled {
  filter: grayscale(100%);
  -webkit-filter: grayscale(100%);
  opacity: .5;
}

.gap-4 {
  grid-gap: 1rem;
}

.gap-8 {
  grid-gap: 2rem;
}

ul.errorlist>li {
  color: red;
  font-size: 80%;
  font-weight: bold;
}

textarea {
  height: 208px;
  padding: 1em;
  line-height: 1.3em;
  font-family: inherit;
}

.col-sidebar textarea {
  height: 130px
}

.m-auto {
  margin: auto
}

.tk-brother-1816 {
  font-family: "brother-1816", sans-serif;
}

.breadcrumbs li a {
  color: var(--secondary)
}

.breadcrumbs li:not(:last-child):after {
  content: " \00bb ";
  color: var(--secondary);
  margin: 0 8px;
  text-decoration: none
}

.breadcrumbs li a:hover {
  text-decoration: underline
}

.listing-icon {
  width: auto;
  height: 100px;
}

.grecaptcha-badge {
  visibility: collapse !important;
}

.col-sidebar ol {
  font-size: .8em;
  margin: 0 .75em 3em;
  padding: 0 .75em;
}

.min-h-3em {
  min-height: 3em;
}

.min-h-4em {
  min-height: 4em;
}

.border-none {
  border: none
}

.trab-border {
  border: 2px solid var(--light);
}

/* .heroInnerWrapper {height: 650px;box-sizing: border-box;} */
.hero-container {
  width: 100%;
  height: 100%;
  margin-bottom: 3em;
}

.hero-slide {
  text-align: center;
  font-size: 18px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  color: #fff;
  height: 60vh;
  min-height: 700px
}

.heroInnerWrapper .circle {
  height: 400px;
  text-align: center;
  align-content: center;
}

[role="table"],
.table-default {
  width: 100%;
  margin-bottom: 2em;
  font-size: .85em
}

[role="table"] tr:nth-child(odd),
.table-default tr:nth-child(odd) {
  background: #f9f9f9
}

[role="table"] tr.styled:nth-child(odd),
.table-default tr.styled:nth-child(odd) {
  background: rgb(0 0 0 / 10%)
}

[role="table"] td,
[role="table"] th,
.table-default td,
.table-default th {
  text-align: left;
  vertical-align: top;
  padding: 14px 2px;
}

[role="table"] td,
.table-default td {
  border-bottom: 1px solid #e2e2e2
}

[role="table"] td:last-child,
[role="table"] th:last-child,
.table-default td:last-child,
.table-default th:last-child {
  text-align: right
}

.table-default[data-layout="course_days"] td,
.table-default[data-layout="course_days"] th {
  padding: 14px 20px;
}

.table-default[data-layout="price_list"] td,
.table-default[data-layout="price_list"] th {
  padding: 4px 10px
}

aside .table-default[data-layout="price_list"] td,
aside .table-default[data-layout="price_list"] th {
  padding: 2px
}

.table-courses .course_class_heading,
.table-courses .course_class {
  padding-left: 20px;
}

.table-courses .course_button_heading,
.table-courses .course_button {
  padding-right: 20px;
}

#navTop [class^="icon-"] {
  color: var(--primary)
}

@media screen and (min-width:1024px) {
  .col-sidebar {
    width: 450px
  }

  .col-content {
    width: calc(100% - 500px)
  }

  #navTop a:hover .label {
    text-decoration: underline;
  }
}

@media screen and (min-width:768px) {
  #navTop li {
    min-width: 76px;
    font-size: .65em
  }

  #navTop [class^="icon-"] {
    font-size: 30px;
  }

  .mob-only {
    display: none !important
  }
}

@media screen and (min-width: 768px) {
  .jumbo .sticker {
    height: 400px;
    border-radius: 50%;
    text-align: center;
    align-content: center;
  }
}

@media screen and (min-width:800px) {
  #navTop li {
    min-width: 80px;
    font-size: .7em
  }

  #navTop [class^="icon-"] {
    font-size: 35px;
  }
}

@media screen and (min-width:1050px) {
  #navTop li {
    min-width: 110px;
    font-size: .75em
  }

  #navTop [class^="icon-"] {
    font-size: 40px;
  }
}

@media screen and (min-width:0px) and (max-width:1023px) {

  .col-sidebar,
  .col-content {
    width: 100%;
    max-width: 100%
  }
}

@media screen and (max-width: 768px) {
  #navTop a {
    padding: 10px 0
  }

  #navTop [class^="icon-"] {
    font-size: 35px;
  }
}

.w300 {
  min-width: 300px
}

#topNav div.col:hover ul {
  display: block;
}

#topNav div.col ul {
  display: hidden;
}

.rich-text>div {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  margin-bottom: 2em
}

.rich-text>div>iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.rich-text ul {
  list-style: initial;
  padding: 0 0 1em 1em;
}

.rich-text ol li {
  padding-bottom: 0.5em
}

.rich-text h1,
.rich-text h2,
.rich-text h3,
.rich-text h4 {
  margin-bottom: 1em
}

.rich-text p {
  margin-bottom: 1.5em
}

.rich-text blockquote {
  border-left: .3em solid var(--primary);
  color: var(--primary);
  padding-left: 1em;
  font-style: italic;
  margin: 1.5em 0;
  padding: 0.5em 0 0.5em 2em;
}

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

.richtext-image {
  border: 10px solid var(--light);
  box-sizing: border-box;
}

.richtext-image.left {
  width: 50%;
  height: auto;
  float: left;
  margin-right: 20px;
}

.richtext-image.right {
  width: 50%;
  height: auto;
  float: right;
  margin-left: 20px;
}

.richtext-image.full-width {
  width: 100%;
  height: auto;
  margin-bottom: 20px
}

.richtext-image.actual {
  border: none;
  margin-bottom: 20px
}

.rich-text a:not(.btn) {
  color: var(--primary);
  text-decoration: underline
}

.z-5 {
  z-index: 5
}

.order-1 {
  order: -1
}

.contact-banner form .btn,
.contact-banner form .input-phone {
  position: relative;
  height: 50px;
  box-sizing: border-box;
  text-align: center;
}

.contact-banner form .btn {
  margin-left: -10px;
}

.contact-banner .input-phone {
  font-size: .8em;
}

.list-services li a {
  min-height: 181px;
}

.list-upcomming-courses i {
  font-size: 90px;
}

.list-instructors .full_name {
  min-height: 2em;
  white-space: nowrap;
  overflow-x: hidden;
  text-overflow: ellipsis;
  font-size: 1em;
}


.border-1 {
  border: var(--secondary) 1px solid
}

.border-2 {
  box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.2);
}

.border-3 {
  border: var(--secondary) 1px solid;
  box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.2);
}

.txt-bold {
  font-weight: 700;
}

.txt-x-bold {
  font-weight: 800;
}

.w-auto {
  width: auto;
}

.margin-20 {
  margin: 20px
}

.margin-r-10 {
  margin-right: 10px;
}

.margin-lr-auto {
  margin-left: auto;
  margin-right: auto;
}

.margin-lr-10 {
  margin-left: 10px;
  margin-right: 10px;
}

.grid-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
}

.h-100 {
  height: 100%;
}

.overflow-hidden {
  overflow: hidden;
}

/* End custom styles */
.btn {
  padding: 0.5em 2.5em;
  text-align: center;
  display: inline-block;
  border: 1px solid transparent;
  border-radius: 40px;
  text-decoration: none;
  cursor: pointer;
  vertical-align: top;
  -webkit-appearance: none;
  outline: 0;
  -webkit-transition: all .2s ease;
  transition: all .2s ease;
  box-sizing: border-box;
  font-family: inherit;
  line-height: 1.7em
}

.btn:hover:not([disabled]) {
  box-shadow: 0 0.5rem 0.5rem rgb(0 0 0 / 15%);
}

.alter-flag {
  width: 40px;
  height: 40px;
  border: 0.2rem solid var(--light);
  border-radius: 50%;
  transition: all .2s;
}

.alter-flag:hover {
  transform: translateY(-4px);
  box-shadow: 0 0.5rem 0.5rem rgb(0 0 0 / 15%);
}

.alter-flag:active:not([disabled]) {
  transform: translateY(-2px);
  box-shadow: 0 0.3rem 0.3rem rgb(0 0 0 / 25%);
}

.btn {
  transition: all .2s;
}

.btn:hover {
  transform: translateY(-4px);
  box-shadow: 0 0.5rem 0.5rem rgb(0 0 0 / 15%);
}

.btn:active:not([disabled]) {
  transform: translateY(-2px);
  box-shadow: 0 0.3rem 0.3rem rgb(0 0 0 / 25%);
}

.btn:hover[disabled] {
  cursor: not-allowed;
}

.cursor-pointer {
  cursor: pointer;
}

.text-normal {
  font-weight: 400;
}

.accent-color input {
  background-color: var(--primary);
  border-color: var(--primary);
}

.grid-auto {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (minmax(320px, 1fr))[auto-fit];
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  grid-gap: 20px
}

.grid-600 {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (minmax(480px, 1fr))[auto-fit];
  grid-template-columns: repeat(auto-fit, minmax(480px, 1fr));
  grid-gap: 40px
}

.minmax-180 {
  -ms-grid-columns: (minmax(180px, 1fr))[auto-fit];
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.gap-0 {
  grid-gap: 0;
}

.gap-5 {
  grid-gap: 5px;
}

.flex-row {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-around;
  align-items: center;
  list-style: none;
}

.flex-row.between {
  justify-content: space-between
}

.flex-row.center {
  justify-content: center
}

.flex-row.end {
  justify-content: flex-end
}

.flex-row.start {
  justify-content: flex-start
}

.flex-row.align-top {
  align-items: flex-start
}

.flex-row.align-bottom {
  align-items: flex-end
}

[class^="container"] {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box
}

.container-1600,
.max-1600 {
  max-width: 1600px
}

.container-1400,
.max-1400 {
  max-width: 1400px
}

.container-1300,
.max-1300 {
  max-width: 1300px
}

.container-1200,
.max-1200 {
  max-width: 1200px
}

.container-1100,
.max-1100 {
  max-width: 1100px
}

.container-1000,
.max-1000 {
  max-width: 1000px
}

.container-900,
.max-900 {
  max-width: 900px
}

.container-850,
.max-850 {
  max-width: 850px
}

.container-800,
.max-800 {
  max-width: 800px
}

.container-750,
.max-750 {
  max-width: 750px
}

.container-700,
.max-700 {
  max-width: 700px
}

.container-650,
.max-650 {
  max-width: 650px
}

.container-600,
.max-600 {
  max-width: 600px
}

.container-550,
.max-550 {
  max-width: 550px
}

.container-500,
.max-500 {
  max-width: 500px
}

.container-450,
.max-450 {
  max-width: 450px
}

.container-400,
.max-400 {
  max-width: 400px
}

.container-350,
.max-350 {
  max-width: 350px
}

.container-320,
.max-320 {
  max-width: 320px
}

.container-300,
.max-300 {
  max-width: 300px
}

.container-250,
.max-250 {
  max-width: 250px
}

.container-200,
.max-200 {
  max-width: 200px
}

.container-170,
.max-170 {
  max-width: 170px
}

.container-150,
.max-150 {
  max-width: 150px
}

.container-125,
.max-125 {
  max-width: 125px
}

.min-h-1000 {
  min-height: 1000px
}

[class^="col"] {
  box-sizing: border-box;
  padding: 10px
}

.col-1of1 {
  width: 100%
}

.col-1of2 {
  width: 50%
}

.col-1of3 {
  width: 33.3333%
}

.col-2of3 {
  width: 66.6666%
}

.col-1of4 {
  width: 25%
}

.col-3of4 {
  width: 75%
}

.col-1of5 {
  width: 20%
}

[class*="padding"] {
  box-sizing: border-box
}

.padding-1 {
  padding: 1px
}

.padding-3 {
  padding: 3px
}

.padding-5 {
  padding: 5px
}

.padding-10 {
  padding: 10px
}

.padding-15 {
  padding: 15px
}

.padding-18 {
  padding: 18px
}

.padding-20 {
  padding: 20px
}

.padding-30 {
  padding: 30px
}

.padding-40 {
  padding: 40px
}

.padding-50 {
  padding: 50px
}

.padding-60 {
  padding: 60px
}

.padding-80 {
  padding: 80px
}

.padding-100 {
  padding: 100px
}

.padding-0 {
  padding: 0
}

.padding-l-10 {
  padding-left: 10px
}

.padding-l-20 {
  padding-left: 20px
}

.padding-l-40 {
  padding-left: 40px
}

.padding-lr-0 {
  padding-left: 0;
  padding-right: 0
}

.padding-lr-5 {
  padding-left: 5px;
  padding-right: 5px
}

.padding-lr-80 {
  padding-left: 80px;
  padding-right: 80px
}

.padding-r-5 {
  padding-right: 5px;
}

.padding-lr-10 {
  padding-left: 10px;
  padding-right: 10px
}

.padding-lr-20 {
  padding-left: 20px;
  padding-right: 20px
}

.padding-lr-30 {
  padding-left: 30px;
  padding-right: 30px
}

.padding-lr-40 {
  padding-left: 40px;
  padding-right: 40px
}

.padding-lr-60 {
  padding-left: 60px;
  padding-right: 60px
}

.padding-t-5 {
  padding-top: 5px
}

.padding-t-10 {
  padding-top: 10px
}

.padding-t-20 {
  padding-top: 20px
}

.padding-t-23 {
  padding-top: 23px
}

.padding-t-30 {
  padding-top: 30px
}

.padding-t-40 {
  padding-top: 40px
}

.padding-t-60 {
  padding-top: 60px
}

.padding-t-80 {
  padding-top: 80px
}

.padding-t-100 {
  padding-top: 100px
}

.padding-t-120 {
  padding-top: 120px
}

.padding-t-0 {
  padding-top: 0
}

.padding-b-5 {
  padding-bottom: 5px
}

.padding-b-10 {
  padding-bottom: 10px
}

.padding-b-15 {
  padding-bottom: 15px
}

.padding-b-20 {
  padding-bottom: 20px
}

.padding-b-30 {
  padding-bottom: 30px
}

.padding-b-40 {
  padding-bottom: 40px
}

.padding-b-60 {
  padding-bottom: 60px
}

.padding-b-80 {
  padding-bottom: 80px
}

.padding-b-100 {
  padding-bottom: 100px
}

.padding-b-0 {
  padding-bottom: 0
}

.padding-r-10 {
  padding-right: 10px
}

.margin-0 {
  margin: 0
}

.margin-left--50p {
  margin-left: -80px;
}

.margin-t-0 {
  margin-top: 0
}

.margin-b-0 {
  margin-bottom: 0
}

.margin-lr-auto {
  margin-left: auto;
  margin-right: auto
}

.margin-tb-20 {
  margin-top: 20px;
  margin-bottom: 20px;
}

.max-w-200 {
  max-width: 200px;
}

.max-w-230px {
  max-width: 230px;
}

.w-full {
  width: 100%;
}

.-order-1 {
  order: -1
}

.dp-14 {
  width: 18px;
  height: 14px
}

.dp-18 {
  width: 18px;
  height: 18px
}

.dp-24 {
  width: 24px;
  height: 24px
}

.dp-26 {
  width: 26px;
  height: 26px
}

.dp-30 {
  width: 30px;
  height: 30px
}

.dp-36 {
  width: 36px;
  height: 36px
}

.dp-40 {
  width: 40px;
  height: 40px
}

.dp-48 {
  width: 48px;
  height: 48px
}

.dp-64 {
  width: 64px;
  height: 64px
}

.h-400 {
  height: 400px
}

.radius-0 {
  border-radius: 0
}

.radius-2 {
  border-radius: 2px
}

.radius-3 {
  border-radius: 3px
}

.radius-4 {
  border-radius: 4px
}

.radius-5 {
  border-radius: 5px
}

.radius-2em {
  border-radius: 2em
}

.radius-30 {
  border-radius: 30px;
}

.circle {
  border-radius: 50%;
  overflow: hidden
}

.v-sub {
  vertical-align: sub
}

.v-middle {
  vertical-align: middle
}

.float-right {
  float: right
}

.float-left {
  float: left
}

.z-bg {
  z-index: -1
}

.z-0 {
  z-index: 0
}

.z-10 {
  z-index: 10
}

.z-98 {
  z-index: 98
}

.z-99 {
  z-index: 99
}

.z-100 {
  z-index: 100
}

.bg-primary {
  background: var(--primary)
}

.bg-secondary {
  background: var(--secondary)
}

.bg-white {
  background: var(--white)
}

.bg-dark {
  background: var(--dark)
}

.bg-gray {
  background: #767676
}

.bg-light {
  background: var(--light)
}

.fill-white {
  fill: var(--white)
}

.fill-dark {
  fill: var(--dark)
}

.fill-light {
  fill: var(--light)
}

.fill-primary {
  fill: var(--primary)
}

.fill-secondary {
  fill: var(--secondary)
}

.txt-small,
small {
  font-size: 80%;
  line-height: 1.5em
}

.txt-medium {
  font-size: 90%;
  line-height: 1.5em
}

.txt-large {
  font-size: 3em;
  line-height: 1.1em;
}

.txt-xlarge {
  font-size: 4em;
  line-height: 1em;
}

.txt-center {
  text-align: center
}

.txt-right,
th.txt-right,
td.txt-right {
  text-align: right
}

.txt-left {
  text-align: left
}

.txt-shadow {
  text-shadow: 1px 1px 1px #000
}

.txt-truncate {
  white-space: nowrap;
  overflow-x: hidden;
  text-overflow: ellipsis
}

.txt-justify {
  text-align: justify
}

.txt-primary,
a.txt-primary {
  color: var(--primary)
}

.txt-secondary,
a.txt-secondary {
  color: var(--secondary)
}

.txt-dark,
a.txt-dark {
  color: var(--dark)
}

.txt-light,
a.txt-light {
  color: var(--light)
}

.txt-grey,
a.txt-grey {
  color: var(--grey)
}

.txt-white,
a.txt-white {
  color: var(--white)
}

.txt-uppercase {
  text-transform: uppercase
}

.txt-underline {
  text-decoration: underline
}

[class^="hover"] {
  transition: .2s ease;
}

.hover-underline:hover {
  text-decoration: underline
}

.hover-opacity:hover {
  opacity: .85
}

.hover-scale:hover {
  transform: scale(1.1)
}

.hover-txt-primary:hover {
  color: var(--primary)
}

.hover-bg-primary:hover {
  background: var(--primary)
}

.hover-txt-white:hover {
  color: var(--white)
}

.relative {
  position: relative
}

.absolute {
  position: absolute
}

.fixed {
  position: fixed
}

.bottom-0 {
  bottom: 0
}

.absolute.center {
  top: 50%;
  left: 50%;
  -webkit-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%)
}

.v-bottom {
  bottom: 5%
}

.v-top {
  top: 5%
}

.h-left {
  left: 5%
}

.h-right {
  right: 5%
}

.hidden,
[hidden] {
  display: none
}

.visuallyhidden {
  border: 0;
  clip: rect(0, 0, 0, 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  white-space: nowrap;
  width: 1px
}

.min-h-3_5em {
  min-height: 3.5em;
}

.min-h-5em {
  min-height: 5em;
}

.hero-info {
  padding: 0;
  align-items: flex-end;
}

.comment-blk {
  width: calc(100% - 170px);
}

.comment-box {
  box-shadow: 2px 2px 4px rgb(0, 0, 0, 0.5)
}

.sticky-content {
  position: sticky
}

.min-h-314 {
  min-height: 314px;
}

.TABS .modal-header {
  background-color: var(--primary)
}

select {
  font-size: .9em;
  background: #fff;
  width: 100%;
  line-height: 2.5em;
  padding: 0 1em;
  box-sizing: border-box;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 2px;
  border: 1px solid #ddd;
  outline: 0;
}

select option {
  font-size: .9em;
  background: #fff;
  width: 100%;
  line-height: 2.5em;
  padding: 0 1em;
  box-sizing: border-box;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 2px;
  border: 1px solid #ddd;
  outline: 0;
}

.flex-row.align-self-start {
  align-self: start;
}

.flex-row.align-self-end {
  align-self: flex-end;
}

.flex-row.comment-blk {
  height: -webkit-fill-available
}

@media only screen and (min-width:481px) and (max-width:1024px) {
  .tab-1of1 {
    width: 100%
  }

  .tab-1of2 {
    width: 50%
  }

  .tab-1of3 {
    width: 33.3333%
  }

  .tab-2of3 {
    width: 66.6666%
  }

  .tab-1of4 {
    width: 25%
  }

  .tab-3of4 {
    width: 75%
  }

  .tab-1of5 {
    width: 20%
  }

  .tab-txt-normal {
    font-size: 100%
  }

  .tab-txt-medium {
    font-size: 90%
  }

  .tab-txt-small {
    font-size: 80%
  }

  .tab-txt-center {
    text-align: center;
  }

  .tab-hidden {
    display: none
  }

  .tab-padding-0 {
    padding: 0
  }

  .tab-padding-10 {
    padding: 10px
  }

  .tab-padding-20 {
    padding: 20px
  }

  .tab-padding-30 {
    padding: 30px
  }

  .tab-padding-50 {
    padding: 50px
  }

  .tab-padding-lr-0 {
    padding-left: 0;
    padding-right: 0;
  }

  .tab-padding-lr-20 {
    padding-left: 20;
    padding-right: 20;
  }

  .tab-padding-lr-40 {
    padding-left: 40px;
    padding-right: 40px;
  }

  .tab-padding-lr-50 {
    padding-left: 50px;
    padding-right: 50px;
  }

  .tab-flex-start {
    justify-content: flex-start;
  }

  .flex-row.tab-start {
    justify-content: flex-start
  }

  .tab-logo-footer {
    width: 200px;
    height: auto;
  }

  .comment-blk {
    width: 100%;
  }

  .comment-blk h3 {
    width: calc(100% - 60px);
    text-align: end;
  }
}

@media screen and (max-width: 1024px) {
  .tab-max-200 {
    max-width: 200px;
  }

  .tab-col-reset {
    width: initial;
  }

}

@media screen and (min-width:1025px) {
  .not-desktop {
    display: none
  }
}

@media screen and (min-width:768px) {
  .desktop-absolute {
    position: absolute;
  }

  .desktop-hidden,
  [hidden] {
    display: none
  }
}

@media screen and (max-width:767px) {
  .mob-1of1 {
    width: 100%
  }

  .mob-1of2 {
    width: 50%
  }

  .mob-1of3 {
    width: 33.3333%
  }

  .mob-2of3 {
    width: 66.6666%
  }

  .mob-1of4 {
    width: 25%
  }

  .mob-3of4 {
    width: 75%
  }

  h1,
  .h1,
  .mob-h1,
  .h1-large,
  .txt-large {
    font-size: 1.7em
  }

  h2,
  .h2,
  .mob-h2 {
    font-size: 1.2em
  }

  h3,
  .h3,
  .mob-h3 {
    font-size: 1.1em
  }

  h4,
  .h4,
  .mob-h4 {
    font-size: 1em
  }

  .mob-bg-none {
    background-color: transparent;
  }

  .mob-hidden {
    display: none
  }

  .mob-margin-0 {
    margin: 0
  }

  .mob-margin-10 {
    margin: 10
  }

  .mob-margin-lr-0 {
    margin-left: 0;
    margin-right: 0
  }

  .mob-margin-lr-10 {
    margin-left: 10px;
    margin-right: 10px
  }

  .mob-padding-0 {
    padding: 0
  }

  .mob-padding-3 {
    padding: 3px
  }

  .mob-padding-5 {
    padding: 5px
  }

  .mob-padding-10 {
    padding: 10px
  }

  .mob-padding-20 {
    padding: 20px
  }

  .mob-padding-30 {
    padding: 30px
  }

  .mob-padding-60 {
    padding: 60px
  }

  .mob-padding-40 {
    padding: 40px
  }

  .mob-padding-50 {
    padding: 50px
  }

  .mob-padding-t-5 {
    padding-top: 5px
  }

  .mob-padding-t-10 {
    padding-top: 10px
  }

  .mob-padding-t-20 {
    padding-top: 20px
  }

  .mob-padding-t-30 {
    padding-top: 30px
  }

  .mob-padding-t-40 {
    padding-top: 40px
  }

  .mob-padding-t-0 {
    padding-top: 0
  }

  .mob-padding-b-5 {
    padding-bottom: 5px
  }

  .mob-padding-b-10 {
    padding-bottom: 10px
  }

  .mob-padding-b-20 {
    padding-bottom: 20px
  }

  .mob-padding-b-30 {
    padding-bottom: 30px
  }

  .mob-padding-b-40 {
    padding-bottom: 40px
  }

  .mob-padding-b-50 {
    padding-bottom: 50px
  }

  .mob-padding-b-0 {
    padding-bottom: 0
  }

  .mob-padding-lr-0 {
    padding-left: 0;
    padding-right: 0
  }

  .mob-padding-lr-5 {
    padding-left: 5px;
    padding-right: 5px
  }

  .mob-padding-lr-10 {
    padding-left: 10px;
    padding-right: 10px
  }

  .mob-padding-lr-20 {
    padding-left: 20px;
    padding-right: 20px
  }

  .mob-esc-lr-10 {
    margin-left: -10px;
    margin-right: -10px;
    width: calc(100% + 20px)
  }

  .mob-esc-lr-20 {
    margin-left: -20px;
    margin-right: -20px;
    width: calc(100% + 40px)
  }

  .mob-gap-0 {
    grid-gap: 0;
  }

  .mob-radius-0 {
    border-radius: 0
  }

  .mob-txt-center {
    text-align: center
  }

  .mob-txt-left {
    text-align: left
  }

  .mob-txt-right {
    text-align: right
  }

  .mob-txt-normal {
    font-size: 100%
  }

  .mob-txt-medium {
    font-size: 90%
  }

  .mob-txt-small {
    font-size: 80%
  }

  .mob-dp-24 {
    width: 24px;
    height: 24px
  }

  .mob-dp-36 {
    width: 36px;
    height: 36px
  }

  .max-h-90vh {
    max-height: 90vh
  }

  .max-h-inherit {
    max-height: inherit
  }

  .grid-600 {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(300px, 1fr))[auto-fit];
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    grid-gap: 40px
  }

  .flex-row.mob-between {
    justify-content: space-between
  }

  .flex-row.mob-center {
    justify-content: center
  }

  .flex-row.mob-end {
    justify-content: flex-end
  }

  .flex-row.mob-start {
    justify-content: flex-start
  }

  .flex-row.mob-align-top {
    align-items: flex-start
  }

  .flex-row.mob-align-bottom {
    align-items: flex-end
  }

  .heroInnerWrapper .mob-circle {
    height: 200px;
    border-radius: 0;
  }

  .mob-border-none {
    border: none
  }

  /* Wagtail styles */
  .logo-top {
    width: 150px
  }

  .responsive-object {
    margin-left: -10px;
    margin-right: -10px;
    width: calc(100% + 20px);
  }

  .max-400.mob-1of1 {
    max-width: 100%;
  }

  #nav {
    background: var(--light)
  }

  /* End Wagtail styles */
  #navTop li.nav-menu-item {
    border: none;
  }

  .hero-slide {
    display: block;
    height: initial;
    min-height: initial;
  }

  .heroInnerWrapper {
    height: 35vh
  }

  .mob-max-calc {
    max-width: calc(100% - 100px)
  }

  .mob-max-100 {
    max-width: 100px
  }

  .contact-banner form .btn {
    margin-left: initial;
    position: absolute;
    right: 10px;
  }

  .table-courses .course_date_heading,
  .table-courses .course_date {
    padding-left: 10px
  }

  .table-courses .course_button_heading,
  .table-courses .course_button {
    padding-right: 10px
  }

  .img-circle {
    width: 50px;
    height: 50px;
    font-size: 2em
  }

  .sticky-content {
    position: static
  }

  .comment-blk {
    width: 100%;
  }

  .comment-blk h3 {
    width: calc(100% - 60px);
    text-align: end;
  }

  .mob-order-1 {
    order: -1
  }

  /* .mob-fixed{position: fixed;} */
  .alter-flag {
    width: 20px;
    height: 20px;
    border: 0.1rem solid var(--light);
    border-radius: 50%;
    transition: all .2s;
  }
}



.sticky-content {
  top: 10px
}


@media screen and (min-width: 1100px) {

  /* main.content, */
  .heroInnerWrapper,
  .top-section {
    margin-top: -200px;
  }
}

@media print {
  html {
    font-size: 12px
  }

  body {
    max-width: 80%;
    padding: 40px 5%
  }

  .list-todo {
    list-style: initial
  }

  .print-hidden,
  .list-todo li:before {
    display: none
  }

  .print-break {
    page-break-before: always;
    padding-top: 60px
  }

  *,
  *:before,
  *:after {
    color: #000;
    box-shadow: none;
    text-shadow: none
  }

  pre {
    white-space: pre-wrap
  }

  pre,
  blockquote {
    border: 1px solid #999;
    page-break-inside: avoid
  }

  thead {
    display: table-header-group
  }

  tr,
  img {
    page-break-inside: avoid
  }

  p,
  h2,
  h3 {
    orphans: 3;
    widows: 3
  }

  h2,
  h3 {
    page-break-after: avoid
  }
}

.max-h-\[90vh\] {
  max-height: 90vh
}

.\[\&\>\*\]\:max-h-\[inherit\]>* {
  max-height: inherit
}

.\[\&\>\*\]\:w-full>* {
  width: 100%
}





@media not all and (min-width: 768px) {
  .max-md\:-order-1 {
    order: -1
  }

  .max-md\:flex {
    display: flex
  }

  .max-md\:flex-wrap {
    flex-wrap: wrap
  }

}

@media (min-width: 768px) {
  .md\:fill-primary li path.fill-white {
    fill: var(--primary)
  }
}


@media not all and (min-width: 1280px) {
  .max-xl\:-order-1 {
    order: -1
  }

  .max-xl\:flex {
    display: flex
  }

  .max-xl\:flex-wrap {
    flex-wrap: wrap
  }
}