/*
	(c)2020 - visuallizard.com

	Base Styles
*/


/*
	Site Specific legend exxample:

	COLOURS:
		#1e90ff		var(--blue) 	[buttons, links]


	FONTS:
		[Proxima Nova: "proxima-nova"]
		Thin 		100
		Light 		300		kit
		Regular 	400 	kit
		Medium 		500
		Semibold 	600 			*use bold instead*
		Bold 		700 	kit
		Extrabold 	800		kit		used [nav, buttons ]
		Black 		900
*/

:root {
    --black: #000000;
    --white: #ffffff;
    --gray: #c0c0c0;
    --ltgray: #f0f0f0;
    --dkgray: #444444;
    --blue: #006688;
    --gold-deep: #7B7A2B;
    --gold: #cecc72;
}

    ::selection {
		background-color: var(--ltgray);
		text-shadow: none;
	}

	html {
		box-sizing: border-box;
		font-size: 62.5%;
		overflow-y: scroll;
		-webkit-text-size-adjust: 100%;
		-ms-text-size-adjust: 100%;
		height: 100%;
	}
	body {
		font: 300 1.6rem/1.75 "Raleway", sans-serif;
		background-color: var(--white);
		color: var(--black);

		position: relative;
		min-height: 100%;
		margin: 0;

		display: flex;
		flex-direction: column;
	}
	main {
		flex-grow: 1;
	}
	*, *:before, *:after {
		box-sizing: inherit;
	}


/* !Typography ============================== */
	h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6 {
		margin: 2rem 0 1rem 0;
	}
    h1, .h1, h2, .h2 {
        text-transform: uppercase;
        letter-spacing: 5%;
    }
	h1 a, .h1 a, h2 a, .h2 a, h3 a, .h3 a, h4 a, .h4 a, h5 a, .h5 a, h6 a, .h6 a {
		font-weight: inherit;
		color: inherit;
	}

	h1, .h1 { font-size: 5.00rem; font-weight: 500; line-height: 1.1; }
	h2, .h2 { font-size: 4.20rem; font-weight: 700; line-height: 1.1; }
	h3, .h3 { font-size: 3.50rem; font-weight: 500; line-height: 1.1; }
	h4, .h4 { font-size: 2.50rem; font-weight: 500; line-height: 1.25; }
	h5, .h5 { font-size: 2.00rem; font-weight: 500; line-height: 1.25; }
	h6, .h6 { font-size: 1.75rem; font-weight: 500; line-height: 1.25; }

	p { margin: 0 0 2.5rem 0; letter-spacing: 2%; }
	p img { margin: 0; max-width: 100%; height: auto !important; }
	p.lead { font-size: 1.75rem; line-height: 1.25;  }

	i, em { font-style: italic; }
	b, strong { font-weight: bold; }
	small, .small { font-size: 80%; }

/*	Blockquotes  */
	blockquote, blockquote p { font-size: 1.75rem; line-height: 1.25; color: var(--dkgray); }
	blockquote { margin: 0 0 20px; padding: 1rem 1.5rem 0 1rem; border-left: 5px solid var(--gray); }
	blockquote cite { display: block; font-size: 0.75rem; color: var(--dkgray); }
	blockquote cite:before { content: "\2014 \0020"; }
	blockquote cite a, blockquote cite a:visited, blockquote cite a:visited { color: var(--dkgray); }



/* !Links */
	a		{ color: var(--gold-deep); outline: 0; font-weight: 500; text-decoration: none; transition: all 0.2s ease; }
	a:hover	{ color: var(--black); outline: 0; text-decoration: underline; }
	a:focus	{ color: var(--gold-deep); outline: 1px dotted var(--black); }
	a:active { outline: 0; }

	p a { line-height: inherit; }


/* !Lists */
	ul, ol { margin: 0 0 2rem 0; }
	ul ul, ul ol, ol ol, ol ul { margin-bottom: 0; }
	ul ul { list-style: circle; }
	ul { list-style: disc; }
	ol { list-style: decimal; }
	li { line-height: inherit; }
	ul.unstyled { list-style: none; margin-left: 0; }


	dl { margin-bottom: 2rem; }
	dl dt, dl dd { line-height: inherit; }
	dl dt { font-weight: bold; }
	dl dd { margin-left: 1em; }

	dd:after {
		/* http://lea.verou.me/2012/02/flexible-multiline-definition-lists-with-2-lines-of-css/ */
		content: '\D\A';
		white-space: pre;
	}

/* !Images */
        figure {
            margin: 0 0 1rem 0;
        }
        img {
            border: 0;
            vertical-align: middle;
            -ms-interpolation-mode: bicubic;
        }
        img.scale-with-grid {
            max-width: 100%;
            height: auto;
        }
        .img-left {
            float: left;
            margin: 0 2rem 2rem 0;
        }
        .img-right {
            float: right;
            margin: 0 0 2rem 2rem;
        }

        .svg-icon,
        .icon-svg,
        svg.icon,
        .icon svg {
            width: 100%;
            height: 100%;
        }
        i.icon {
            width: 2rem;
            height: 2rem;
            display: inline-block;
            vertical-align: middle;
        }

    /* !Other */
        code, pre {
            padding: 0 3px 2px;
            font-family: Monaco, Andale Mono, Courier New, monospace;
            font-size: 12px;
            border-radius: 3px;
            border: 1px solid var(--ltgray);
        }
        code {
            background-color: var(--ltgray);
            color: var(--black);
            padding: 1px 3px;
        }
        pre {
            background-color: #f5f5f5;
            display: block;
            padding: 8.5px;

            border: 1px solid var(--ltgray);
            white-space: pre;
            white-space: pre-wrap;
            word-wrap: break-word;
        }

        hr {
            clear: both;
            height: 0;
            margin: 1em 0;
            border: 0;
            border-bottom: 1px solid var(--ltgray);
        }

        address {
            display: block;
            line-height: 18px;
            margin-bottom: 18px;
        }

        .lower { text-transform: lowercase; }
        .upper { text-transform: uppercase; }


        sub, sup {
            /* Specified in % so that the sup/sup is the
             right size relative to the surrounding text */
            font-size: 75%;

            /* Zero out the line-height so that it doesn't
             interfere with the positioning that follows */
            line-height: 0;

            /* Where the magic happens: makes all browsers position
             the sup/sup properly, relative to the surrounding text */
            position: relative;

            /* Note that if you're using Eric Meyer's reset.css, this
             is already set and you can remove this rule */
            vertical-align: baseline;
        }
        sup {
            /* Move the superscripted text up */
            top: -0.5em;
        }
        sub {
            /* Move the subscripted text down, but only
             half as far down as the superscript moved up */
            bottom: -0.25em;
        }

    /* ! Helper classes  */
        .hidden {
            display: none !important;
            visibility: hidden;
        }
        .visuallyhidden {
            border: 0;
            clip: rect(0 0 0 0);
            height: 1px;
            margin: -1px;
            overflow: hidden;
            padding: 0;
            position: absolute;
            width: 1px;
        }
        .visuallyhidden.focusable:active,
        .visuallyhidden.focusable:focus {
            clip: auto;
            height: auto;
            margin: 0;
            overflow: visible;
            position: static;
            width: auto;
        }
        .invisible {
            visibility: hidden;
        }
        .clearfix:after {
            content: "";
            display: table;
            clear: both;
        }


    /* ! Buttons ============================== */
        .button {
            display: inline-block;
            vertical-align: middle;
            padding: .6em 1em .4em;
            padding: .5em 1em .3em;
            min-width: 6em;

            color: #fff;
            background-color: var(--blue);
    /* 		background-image: linear-gradient(#fff, #fff 25%, #e6e6e6); */
            background-repeat: no-repeat;
            background-repeat: repeat-x;
            background-origin: border-box;

            text-align: center;
            text-decoration: none;
            text-transform: uppercase;
            letter-spacing: 0.01em;

            font-family:  sans-serif;
            font-size: 14px;
            line-height: 1.3;

            border: 1px solid    rgba(0, 0, 0, .05);
            border-bottom-color: rgba(0, 0, 0, .07);
            border-radius: 2px;

            -webkit-appearance: none;
               -moz-appearance: none;
                    appearance: none;

            cursor: pointer;
            transition: 0.1s linear all;
        }
        .button:hover {
            background-color: var(--black);
            text-decoration: none;
        }
        .button:active,
        .button.active {
            border-color: var(--ltgray);
        }
        .button:focus {
            outline: 1px dotted var(--dkgray);
            outline-offset: 1px;
        }
        .button.disabled,
        .button[disabled] {
            background-image: none;
            opacity: 0.5;
            box-shadow: none;
            pointer-events: none;
            cursor: default;
        }
        .button.outline {
            color: var(--blue);
            border-color: currentColor;
            background-color: transparent;
        }
        .button.outline:hover {
            color: var(--black);
        }

    /* ! FORMS ============================== */
        form {
            margin-bottom: 2em;
        }
        fieldset {
            margin-bottom: 2em;
        }
        fieldset > :last-child {
            margin-bottom: 0;
        }
        label,
        legend {
            display: block;
            margin-bottom: auto;
            font-size: .875rem;
            font-weight: bold;
        }
        .required > label:after {
            content: " *";
        }

        input,
        select,
        textarea,
        output {
            display: inline-block;
            vertical-align: middle;
            border: 1px solid var(--ltgray);
            padding: .3em .5em .4em;
    /* 		outline: none; */
            border-radius: 2px;
            font: 300 16px/1.25 "HelveticaNeue", "Helvetica Neue", Helvetica, Arial, sans-serif;
            color: var(--dkgray);
            margin: 0;
            max-width: 100%;
            min-width: 80px; /* ensure the input fields (such as with class .w5) are not too small when on narrow breakpoints  */
            background: var(--white);
            accent-color: var(--blue);
        }
        input:focus,
        select:focus,
        textarea:focus,
        output:focus {
            border-color: var(--blue);
            outline: 0;
            -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6);
                    box-shadow: inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6);
        }
        select {
            /* padding: initial; */

            /* for custom selects: */
            padding: .2em .5em .3em;
            padding-right: 1.5em;
            border: 1px solid var(--ltgray);
            border-radius: 2px;
            min-width: 10em;
            max-width: 100%;

            -webkit-appearance: none;
               -moz-appearance: none;
                    appearance: none;

            background-color: #fff;
            background-repeat: no-repeat;
            background-size: auto 35%;
            background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cpolygon fill='%23cccccc' points='0,10 50,90 100,10'/%3E%3C/svg%3E");
            background-position: 95% center;
            background-position: right .5em top 55%;

            cursor: pointer;
        }

        [class^='input-'] {
            margin-bottom: 1rem;
        }

        [type="checkbox"],
        [type="radio"] {
            width: auto;
            height: auto;

            width: 1.25rem;
            height: 1.25rem;

            min-width: 0;
            padding: 0;
            margin: 0 .5rem 0 0;

            line-height: initial;
            border: none;
            display: inline-block;
            vertical-align: text-top;
        }
        .input-checkbox label,
        .input-radio    label {
            margin-right: 1em;
            display: inline-block;
            vertical-align: text-top;
            max-width: calc(100% - 3rem); /*  to avoid dropping into new lines on narrow breakpoints. */
            font-weight: normal;
        }

        /* Multiple sets */
        .fm-checkbox > label:first-child,
        .fm-radio > label:first-child {
            display: block;
            font-weight: bolder;
        }

        .input-check-option,
        .input-radio-option {
            display: block;
            margin-bottom: 0;

            /* Spread options into three columns */
            display: inline-block;
            vertical-align: text-top;
            width: 33%;
            min-width: 200px;
        }
        .input-check-option input,
        .input-radio-option input {
            float: left;
        }
        .input-check-option label,
        .input-radio-option label {
            display: block;
            margin: 0 1.5em;
            font-weight: normal;
        }


        /* 	File Input Upload */
        .js [type="file"] {
            width: 0.1px;
            height: 0.1px;
            opacity: 0;
            overflow: hidden;
            position: absolute;
            z-index: -1;
        }
        [type="file"] + label {

        }
        [type="file"] + label output {
            display: flex;
            flex-direction: row;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
            cursor: pointer;
        }
            [type="file"] + label output strong {
                font-weight: normal;
                color: var(--blue);
                margin-left: auto;
            }
            [type="file"] + label output .icon {
                margin-top: -0.25em;
                margin-right: 0.25em;
            }
        [type="file"]:focus + label output,
        [type="file"] + label:hover output {
            color: var(--blue);
            border-color: currentColor;
        }
        .no-js [type="file"] + label,
        .no-js [type="file"] + label output {
            display: none;
        }


        /* 	Input Error Messages */
        .error-message {
            margin-bottom: 0;
            padding: .25rem .5rem;
            background-color: rgba(197, 61, 53, 0.1);
            color: rgba(197, 61, 53, 1);
            line-height: 1.3;
            font-size: small;
        }
        .input-checkbox .error-message {
            margin-top: .25em;
        }

        .controls-group {
            clear: both;
            padding: 0;
            margin: 0 0 1rem 0;
        }
            .controls-group > .button {
                margin-bottom: .25rem;
            }
            .controls-group > .button + .button {
                margin-left: 1rem;
            }
            .controls-group > .next {
                float: right;
            }

        .form-row {

        }

        /* Form Module */
        .fm-form {
            max-width: 600px;
        }
        .fm-form [type="url"],
        .fm-form [type="tel"],
        .fm-form [type="text"],
        .fm-form [type="email"],
        .fm-form [type="number"],
        .fm-form [type="password"],
        .fm-form select,
        .fm-form textarea {
            width: 100%;
        }

        /* Auth Forms */
        .auth-block {
            max-width: 600px;
            margin: 2rem auto;
        }
            .auth-form {
                max-width: 300px;
            }
            .auth-form input {
                width: 100%;
            }

        /* 	Display classes */
        .block { display: block; }
        .inline { display: inline; }
        .inblock { display: inline-block; }

        /* 	Alignment */
        .left { text-align: left; }
        .right { text-align: right; }
        .center { text-align: center; }

        /* Opacity levels */
        .o0  { opacity:  0; }
        .o10 { opacity: .1; }
        .o20 { opacity: .2; }
        .o30 { opacity: .3; }
        .o40 { opacity: .4; }
        .o50 { opacity: .5; }
        .o60 { opacity: .6; }
        .o70 { opacity: .7; }
        .o80 { opacity: .8; }
        .o90 { opacity: .9; }
        .o100 { opacity: 1; }

        /* Blocking	widths */
        .w5  { width: 5%; }
        .w10 { width: 10%; }
        .w15 { width: 15%; }
        .w20 { width: 20%; }
        .w25 { width: 25%; }
        .w30 { width: 30%; }
        .w35 { width: 35%; }
        .w40 { width: 40%; }
        .w45 { width: 45%; }
        .w50 { width: 50%; }
        .w55 { width: 55%; }
        .w60 { width: 60%; }
        .w65 { width: 65%; }
        .w70 { width: 70%; }
        .w75 { width: 75%; }
        .w80 { width: 80%; }
        .w85 { width: 85%; }
        .w90 { width: 90%; }
        .w95 { width: 95%; }
        .w100 { width: 100%; }

        /* Lines clamping (truncating) */
        .l1, .l2, .l3, .l4, .l5, .l6, .l7, .l8, .l9, .l10 {
            text-overflow: ellipsis;
            overflow: hidden;
            display: -webkit-box;
            -webkit-box-orient: vertical;
            -webkit-line-clamp: 1;
        }
        .l1  { -webkit-line-clamp: 1; }
        .l2  { -webkit-line-clamp: 2; }
        .l3  { -webkit-line-clamp: 3; }
        .l4  { -webkit-line-clamp: 4; }
        .l5  { -webkit-line-clamp: 5; }
        .l6  { -webkit-line-clamp: 6; }
        .l7  { -webkit-line-clamp: 7; }
        .l8  { -webkit-line-clamp: 8; }
        .l9  { -webkit-line-clamp: 9; }
        .l10 { -webkit-line-clamp: 10; }


    /* ! Content module columns */
        .cke {
            display: flex;
            flex-wrap: wrap;
            justify-content: space-between;

            --col-gap: 4rem;
            --col-gap: 4vw;
            column-gap: var(--col-gap);
        }
        .cke > .c2,
        .cke > .c3,
        .cke > .c4,
        .cke > .c5,
        .cke > .c6 {
            --col: 1;
            flex-grow: 1;
            /* padding-block: 2rem; */
            /* margin-left: initial; */
            width: calc( (100% - var(--col-gap) * var(--col)) / var(--col) );
        }

        .cke > .c1 { --col: 1; }
        .cke > .c2 { --col: 2; }
        .cke > .c3 { --col: 3; }
        .cke > .c4 { --col: 4; }
        .cke > .c5 { --col: 5; }
        .cke > .c6 { --col: 6; }

        .cke > .c-first.c-last { width: 100%; }

    /* ! CSS columns */
        .columns-2 { columns: 2 500px; column-gap: 3em; }
        .columns-3 { columns: 3 250px; column-gap: 3em; }
        .columns-4 { columns: 4 250px; column-gap: 3em; }


    /* ! Debug Body Classes */
        body::before,
        body::after {
            position: fixed;
            top: 0px;
            z-index: -1;
            visibility: hidden;
        }
        body.debug:after {
            content: attr(class);
            right: 0;
        }
        body.debug::before,
        body.debug::after {
            display: inline-block;
            padding: 0 .5em;
            color: #ccc;
            background: var(--black);
            z-index: 1000;
            font-size: 10px;
            visibility: visible;
        }

    /* ! Dev. Site indicator */
        .debug-indicator {
            display: block;
            padding: .5em;
            background-color: #fc0;
            background-image: repeating-linear-gradient(45deg, transparent, transparent 7px, #330 7px, #330 14px);
            text-align: center;
        }
            .debug-indicator p {
                display: inline-block;
                margin: 0;
                padding: .293em 1em;
                background-color: black;

                color: white;
                line-height: 1.4em;
                text-transform: uppercase;
                font-size: 12px;
                font-family: courier, serif;
                font-weight: normal;
                letter-spacing: 0.1em;
            }
            .debug-indicator span {
                font-size: 1.5em;
                line-height: 1;
                cursor: help;
            }



    /* ! Messages ============================== */
        #flashMessage {

        }
        .message {
            position: relative;
            padding: .5em 1em .4em;
            margin-bottom: 1em;
            font-size: 16px;
            letter-spacing: 0.01em;
            color: #856404;
            background-color: #fff3cd;
            border-left: 6px solid currentColor;
        }
            .message.success { background-color: rgba(85, 168, 85, 0.1);  color: rgba(85, 168, 85, 1); }
            .message.error {   background-color: rgba(197, 61, 53, 0.1);  color: rgba(197, 61, 53, 1); }
            .message.info {    background-color: rgba(52, 157, 186, 0.1); color: rgba(52, 157, 186, 1);}

        .message a {
            font-weight: bolder;
            color: inherit;
        }
        .message > :last-child {
            margin-bottom: 0;
        }
        .message .close	{
            float: right;
            color: var(--black);
            font-size: 20px;
            font-weight: bold;
            line-height: initial;
            text-shadow: 0 1px 0 #fff;
            text-decoration: none;
            opacity: 0.5;
        }
        .message .close:hover{
            color: var(--black);
            text-decoration: none;
            opacity: 0.75;
        }


    /* ! Cards items */
        .cards {
            display: flex;
            flex-direction: row;
            flex-wrap: wrap;
            justify-content: center;
            width: 103%;
            margin: 1em -1.5% 0;
            padding: 0;
            list-style-type: none;
        }
        .card {
            width: 30%;
            margin: .8em 1.5%;
            padding: 0 1em 1em;
            background-color: white;
            box-shadow: 0 0 2px 2px rgba(0,0,0,0.05);

            display: flex;
            flex-direction: column;
        }
            .card .more {
                margin-top: auto; /* to push item to the end of flex axis */
                margin-bottom: 0;
                flex-grow: 0;
            }
        .card-img {
            display: block;
            width: 100%;
            margin: 0;
            transition: all .5s ease;
        }
        .card-link {
            display: block;
            width: calc(100% + 2em);
            margin: 0 -1em 1em;
            overflow: hidden;
        }
        .card-link:hover .card-img {
            transform: scale(1.1);
        }

        /* 	for 4, 8, 12, 4n… */
        .card:nth-last-child(2):first-child,
        .card:nth-last-child(2):first-child ~ .card,
        .card:nth-last-child(4n):first-child,
        .card:nth-last-child(4n):first-child ~ .card {
            width: 45%;
            margin-left: 2%;
            margin-right: 2%;
        }


    /* !Media grid ============================== */
        .media-grid {
            margin-left: -20px;
            margin-bottom: 0;
        }
        .media-grid:before, .media-grid:after {
            display: table;
            content: "";
        }
        .media-grid:after {
            clear: both;
        }
        .media-grid li {
            display: inline;
        }
        .media-grid a, .media-grid div.group {
            float: left;
            padding: 4px;
            margin: 0 0 20px 20px;
            border: 1px solid var(--ltgray);
            border-radius: 2px;
            box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075);
        }
        .media-grid a img {
            display: block;
        }
        .media-grid a:hover {
            border-color: #7a2;
            box-shadow: 0 1px 4px rgba(0, 105, 214, 0.25);
        }
        .media-grid .caption {
            display: block;
        }



    /* !Tabs (activate in tabs.js) ============================== */
        .tabs-nav {
            display: block;
            margin: 0;
            padding: 0;
        }
        .tabs-nav li {
            display: block;
            width: auto;
            padding: 0;
            float: left;
            margin-bottom: 0;
        }
        .tabs-nav li a {
            display: block;
            text-decoration: none;
            width: auto;
            min-height: 34px;
            padding: 10px 20px;
            border: solid 1px var(--ltgray);
            border-width: 1px 1px 0 0;
            margin: 0;
            background: #f6f6f6;
            font-size: 13px;
        }
            .tabs-nav li a:hover {
                background: #f0f0f0;
            }
        .tabs-nav li a.active {
            background: #fff;
            position: relative;
            padding-bottom: 11px;
            margin-bottom: -1px;
            border-left-width: 1px;
            margin: 0 0 -1px -1px;
            color: #111;
            border-top-left-radius: 3px;
            border-top-right-radius: 3px;
        }
        .tabs-nav li:first-child a.active {
            margin-left: 0;
        }
        .tabs-nav li:first-child a {
            border-width: 1px 1px 0 1px;
            border-top-left-radius: 3px;
        }
        .tabs-nav li:last-child a {
            border-top-right-radius: 3px;
        }

        .tabs-content { margin: 0; padding: 2em; border: 1px solid var(--ltgray); display: block; list-style: none; clear: both;}
        .tabs-content > .tab { display:none; }
        .tabs-content > .tab.active { display: block; }



    /* !Tables	============================== */
        .table-wrap {
            max-width: 100%;
            margin-bottom: 3rem;
            overflow-x: auto;
            -ms-overflow-style: none;
        }
        table {
    /* 		table-layout: fixed; */
            width: 100%;
            padding: 0;
            font-size: 1.6rem;
            border-collapse: collapse;
            max-width: 100%;
            overflow-x: scroll;
        }
        table th,
        table td {
            padding: 1rem 1rem 0.85rem 0.85rem;
            line-height: 1.125;
            text-align: left;
        }
        table th {
            padding-top: 1rem;
            font-weight: bold;
            vertical-align: middle;
        }
        table td {
            vertical-align: top;
            border-top: 1px solid var(--ltgray);
        }
        table tbody th {
            border-top: 1px solid var(--ltgray);
            vertical-align: top;
        }

        /* 	table types: .condensed	and .bordered */
        .condensed th,
        .condensed td {
            padding: .25em .25em .2em;
        }
        .bordered {
            border: 1px solid var(--ltgray);
        }
        .bordered th + th,
        .bordered td + td,
        .bordered th + td {
            border-left: 1px solid var(--ltgray);
        }

        /* 	sortable and zebra-striped tables */
        .striped tbody tr:nth-child(odd) td,
        .striped tbody tr:nth-child(odd) th {
            background-color: #f9f9f9;
        }
        .striped tbody tr:hover td,
        .striped tbody tr:hover th {
            background-color: #f5f5f5;
        }
        table .header {
            cursor: pointer;
        }
        table .header:after {
            content: "";
            float: right;
            margin-top: 7px;
            border-width: 0 4px 4px;
            border-style: solid;
            border-color: #000 transparent;
            visibility: hidden;
        }
        table .headerSortUp,
        table .headerSortDown {
            background-color: #85c446;
            background-color: rgba(133,196,70,.3);
            text-shadow: 0 1px 1px rgba(255, 255, 255, 0.75);
        }
        table .header:hover:after {
            visibility: visible;
        }
        table .headerSortDown:after,
        table .headerSortDown:hover:after {
            visibility: visible;
            opacity: 0.6;
        }
        table .headerSortUp:after {
            border-bottom: none;
            border-left: 4px solid transparent;
            border-right: 4px solid transparent;
            border-top: 4px solid #000;
            visibility: visible;
            box-shadow: none;
            opacity: 0.6;
        }


    /* !Pagination	============================== */
        .pagination-links {
            clear: both;
            margin: 2em 0;
            padding: 0;
            overflow: hidden;
            -moz-user-select: none;
                 user-select: none;
        }
        .pagination-links li {
            display: block;
            float: left;
            margin: 0;
            padding: 0;
        }
        .pagination-links a,
        .pagination-links .current {
            display: block;
            padding: 0 1em;
            font-family: Consolas, Monaco, monospace;
            line-height: 2.25em;
            text-decoration: none;
            border-right: 1px solid rgba(0, 0, 0, 0.15);
        }
        .pagination-links a:hover,
        .pagination-links .active a,
        .pagination-links .current {
            background-color: rgba(0, 0, 0, 0.05);
        }
        .pagination-links .disabled a,
        .pagination-links .disabled a:hover {
            background-color: transparent;
            color: #bfbfbf;
        }
        .pagination-links li:last-child a {
            border-right: none;
        }



    /* ! Slick Slider default styles ============================== */
        .slick-slider {
            position: relative;
            display: block;
            -moz-box-sizing: border-box;
                 box-sizing: border-box;

            -webkit-user-select: none;
               -moz-user-select: none;
                -ms-user-select: none;
                    user-select: none;

            -webkit-touch-callout: none;
            -khtml-user-select: none;
            -ms-touch-action: pan-y;
                touch-action: pan-y;
            -webkit-tap-highlight-color: transparent;
        }
        .slick-list {
            position: relative;
            display: block;
            overflow: hidden;
            margin: 0;
            padding: 0;
        }
        .slick-list:focus {
            outline: none;
        }
        .slick-list.dragging {
            cursor: pointer;
            cursor: hand;
        }
        .slick-slider .slick-track,
        .slick-slider .slick-list {
            -webkit-transform: translate3d(0, 0, 0);
               -moz-transform: translate3d(0, 0, 0);
                -ms-transform: translate3d(0, 0, 0);
                 -o-transform: translate3d(0, 0, 0);
                    transform: translate3d(0, 0, 0);
        }
        .slick-track {
            position: relative;
            top: 0;
            left: 0;
            display: block;
            margin-left: auto;
            margin-right: auto;
        }
        .slick-track:before,
        .slick-track:after {
            display: table;
            content: '';
        }
        .slick-track:after {
            clear: both;
        }
        .slick-loading .slick-track {
            visibility: hidden;
        }
        .slick-slide {
            display: none;
            float: left;

            height: 100%;
            min-height: 1px;
        }
        [dir="rtl"] .slick-slide {
            float: right;
        }
        .slick-slide img {
            display: block;
        }
        .slick-slide.slick-loading img {
            display: none;
        }
        .slick-slide.dragging img {
            pointer-events: none;
        }
        .slick-initialized .slick-slide {
            display: block;
        }
        .slick-loading .slick-slide {
            visibility: hidden;
        }
        .slick-vertical .slick-slide {
            display: block;
            height: auto;
            border: 1px solid transparent;
        }
        .slick-arrow.slick-hidden {
            display: none;
        }

        /* Slick Slider additional project specific styles */
        .slick-arrow {
            position: absolute;
            top: 0;
            width: 2%;
            height: 100%;
            text-indent: -20em;
            overflow: hidden;
            border: none;
            color: #444;
            background-color: rgba(255,255,255,0);
            background-position: center center;
            background-repeat: no-repeat;
            background-size: 50% auto;
            transition: all .2s;
            opacity: .5;
            cursor: pointer;
            z-index: 100;
        }
        .slick-arrow:hover {
            background-color: rgba(255,255,255,.5);
        }
        .slick-prev { left: 0;  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 50 100"><polygon fill="%23444444" points="50,14.4 14.4,50 50,85.6 50,100 0,50 0,50 50,0"/></svg>'); }
        .slick-next { right: 0; background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 50 100"><polygon fill="%23444444" points="0,14.4 35.6,50 0,85.6 0,100 50,50 50,50 0,0"/></svg>'); }

        /* Banner dots */
        .slick-dots {
            list-style: none;
            position: absolute;
            bottom: 1em;
            margin: 0 auto;
            text-align: center;
            width: 100%;
            left: 0; right: 0;
            line-height: 1;
        }
            .slick-dots > li {
                display: inline-block;
                margin: 0 .25em;
                text-align: center;
            }
            .slick-dots > li > button {
                display: block;
                border: 1px solid rgba(100,100,100,.90);
                border-radius: 100%;
                background: none;
                text-indent: -10em;
                overflow: hidden;
                margin: 0;
                padding: 0;
                width: 16px;
                height: 16px;
                cursor: pointer;
            }
            .slick-dots > li:hover > button,
            .slick-dots > li.slick-active > button {
                background-color: rgba(0, 0, 0, .5);
            }
        button.slick-autoplay-toggle-button {
            display: flex;
            position: absolute;
            justify-content: space-between;
            align-items: center;
            column-gap: 1rem;
            bottom: -2rem;
            right: 4rem;
            z-index: 1;
            max-width: none;
            border: none;
            background: none;
            cursor: pointer;
        }
            button.slick-autoplay-toggle-button span.slick-pause-icon {
                display: inline-block;
                width: 20px;
                height: 20px;
                border-left: 9px solid var(--black);
                border-right: 9px solid var(--black);
            }
            button.slick-autoplay-toggle-button span.slick-play-icon {
                display: inline-block;
                width: 20px;
                height: 20px;
                border-top: 10px solid transparent;
                border-right: 0;
                border-bottom: 10px solid transparent;
                border-left: 20px solid var(--black);
            }



    /* ! Toggles - general ============================== */

    /* These styles are mainly for functionality and usability.
     * Overwrite as needed based on specific module.
     */
    .toggle {
        position: absolute;
        border: none;
        padding: 0;
        margin: 0;
        background: transparent;
        left: auto;
        right: 1rem;
        top: 1rem;
        color: inherit;
        width: 2rem;
        height: 2rem;
        min-width: 0;
        cursor: pointer;
        transform-origin: center;
        transition: transform .2s;
    }
        .toggle:hover {
            background: transparent;
            color: inherit;
        }
        .toggle:focus {
            outline: 1px dotted currentColor;
        }
        .toggle .svg-icon {
            display: block;
            width: 100%;
            height: 100%;
            transform-origin: center;
        }

        .toggle-unit {
            margin: 0 0 1rem 0;
            position: relative;
            z-index: 0;
        }
        .toggle-unit.is-toggle-on {
            z-index: 1;
        }
        .toggle-unit.is-toggle-on .toggle {
            transform: rotate(-90deg);
            opacity: .8;
        }
        .toggle-details {
            margin: 0;
            padding: 0 2rem;
            overflow: hidden;
            max-height: 0;
            transition: all .2s ease-in-out;
        }
            .is-toggle-on .toggle-details,
                   .no-js .toggle-details {
                opacity: 1;
                max-height: 99999px;
                margin-bottom: 1rem;
                padding: 1rem 2rem;
                will-change: opacity, max-height, margin, padding;
            }
            .is-toggle-off .toggle-details {
                opacity: 0;
                max-height: 0;
                margin-bottom: 0;
            }
        .toggle-head {
            position: relative;
            padding: .5rem 4rem .5rem 2rem;
            margin: 0;
            border-radius: 0;

            color: #fff;
            background-color: var(--blue);

            z-index: 1;
            cursor: pointer;
            transition: .2s all;
        }
            .toggle-head:hover,
            .is-toggle-on > .toggle-head {
                background-color: var(--black);
            }
            .toggle-head > .toggle-title {
                padding: 0;
                margin-top: .5rem;
                margin-bottom: .25rem;
                line-height: 1.5;
                color: inherit;
                cursor: pointer;
            }


    /* ! Magnific Popup */
        .default-popup {
            position: relative;
            background: #fff;
            padding: 20px;
            width: auto;
            max-width: 560px;
            margin: 20px auto;
        }

    /* JS helper classes: */
        .no-js .no-js-show {
            display: block;
        }
        .no-js .no-js-hide {
            display: none;
        }

    /* ! Skip Nav (Accessibility navigation) */
        .skip-nav a {
            border: 0;
            clip: rect(0 0 0 0);
            width: 1px;
            height: 1px;
            margin: -1px;
            overflow: hidden;
            position: absolute;
            left: 20px;
            top: 20px;
            white-space: nowrap;
            z-index: 1;

            padding: .25rem .5rem;
            background: #ffffffcc;
            color: var(--blue);
        }
        .skip-nav a:focus,
        .skip-nav a:active {
            position: absolute;
            margin: 0;
            height: auto;
            width: auto;
            overflow: hidden;
            clip: auto;
        }

    /* ! Tooltips */
        [data-tooltip] {
            position: relative;
            text-decoration: underline;
            text-decoration-style: dashed;
        }
            [data-tooltip]:before {
                opacity: 0;
                transition: opacity .2s;
            }
            [data-tooltip]:hover:before {
                content: attr(data-tooltip);
                display: block;
                position: absolute;
                bottom: 100%;
                left: 1em;
                transition: all .2s;
                padding: .5em .75em;
                background-color: var(--black);
                color: #fefefe;
                border-color: currentColor;
                border-radius: .5rem;
                border-bottom-left-radius: 0;
                font-size: small;
                font-weight: 100;
                line-height: 1.25;
                letter-spacing: normal;
                min-width: 200px;
                max-width: 400px;
                box-shadow: 0 0 8px 2px rgba(0,0,0,.1);
                opacity: 1;
            }
