/* ------------------------------------------------------------ *\
	Section
\* ------------------------------------------------------------ */

.section { padding: 50px 0; font-size: 14px; }
.section:first-child { padding-top: 0; }
.section p { font-size: 15px; line-height: 1.67; }
.section h1 { font-size: 27px; font-weight: 400; }

.section .row { padding-top: 15px; padding-bottom: 15px; }

.section .section__head { margin-bottom: 15px; }
.section .section__head h4 { font-size: 30px; }

.section .section__image { position: relative; }
.section .section__image img { width: 100%; height: auto; }
.section .section__image .btn { position: absolute; bottom: 30px; left: 50%; transform: translateX(-50%); }

.section .section__image-heading { position: absolute; bottom: 0; left: 0; width: 100%; background: #000; opacity: .8; padding: 20px 30px 20px; }
.section .section__image-heading > * { color: #fff; text-align: center; line-height: 1.2; }


/* Mobile */

@media( max-width: 767px ) {
	.section .section__head h4 { font-size: 25px; }
}

/* ------------------------------------------------------------ *\
	 Section Slider Main
\* ------------------------------------------------------------ */

.section-slider-main { padding: 0; position: relative; width: 100vw; height: 500px; margin-left: -50vw; left: 50%; margin-bottom: 26px; }

/* Tablet Portrait */

$breakpoint-tablet-portrait {
	.section-slider-main { height: auto; margin-bottom: 0; }
}

/* Mobile */

@media( max-width: 767px ) {
	.section-slider-main { padding-top: 0 !important; }
	.section p { font-size: 15px; }
}


/* ------------------------------------------------------------ *\
		Section Halfs
\* ------------------------------------------------------------ */

.section--halfs { font-size: 20px; line-height: 1.825; padding: 30px 0; }
.section--halfs .section__image { overflow: hidden; border-radius: 6px; }

.section--halfs .row .row__head { display: block; width: 100%; margin-bottom: 20px; padding: 0 15px; }
.section--halfs .row .row__head > * { font-size: 27px; font-weight: 400; }
.section--halfs .row__background { position: absolute; width: 100vw; height: 100%; top: 0; margin-left: -50vw; left: 50%; margin-bottom: 0; z-index: 0; }

.section--halfs .row > * { position: relative; z-index: 2; }
.section--halfs .row__head h1 { letter-spacing: -0.02em; }

/* Large Centered Title */
.section--halfs .row.section--title .row__head h3 { font-size: 35px; color: #0855b1 !important; text-align: center; font-weight: 500; }

.section--halfs .row.section--title.text-lg .col-12 { font-size: 20px; line-height: 1.79; text-align: center; }
.section--halfs .row.section--title.text-lg .col-12 p { padding: 0 60px; font-size: 19px; letter-spacing: 0.01em; }
.section--halfs .row.section--title.text-lg .col-12 a { text-decoration: none; color: #2280c8; }

.section--halfs .btn { position: absolute; bottom: 0; margin-top: 35px; left: 15px; }
.section--halfs .btn.btn--separator { position: relative; color: #fff; background: #fff; }

.section + .section--halfs .row__background { top: -42px; bottom: -32px; height: auto; }

.section--halfs .video { padding-bottom: 64.25%; }
.section--halfs .video .video__ico { width: 80px; height: 80px; }

.section--halfs .section__image-heading h4 { font-size: 30px; margin-bottom: 0; }

.section--halfs .col-12 h5 { font-size: 18px; color: #000; }

.section--halfs .row + .row { margin-top: 50px; }


/* Tablet Portrait */

$breakpoint-tablet-portrait {
	.section--halfs { padding: 30px 0; font-size: 18px; line-height: 1.6; }
	.section--halfs br { display: none; }
	.section--halfs .row .row__head > *,
	.section--halfs .row.section--title .row__head h3  { font-size: 35px; }
	.section--halfs .row.section--title.text-lg .col-12 { font-size: 18px; line-height: 1.6; }
}

/* Mobile */

@media(max-width: 767px) {
		.section--halfs .col-12 { margin-bottom: 15px; }
		.section--halfs .col-12:last-child {
			margin-bottom: 0;
		}

		.section--halfs .row .row__head > *,
		.section--halfs .row.section--title .row__head h3  { font-size: 32px; }
		.section--halfs .row.section--title.text-lg .col-12 { font-size: 17px; line-height: 1.35; }
		.section--halfs .row.section--title.text-lg .col-12 p { padding: 0; }
		.section.section--halfs { padding-bottom: 0; }
		.section--halfs  .col-md-6 + .col-md-6 { margin-top: 20px; }
		.section--halfs .row + .row { padding-top: 0; }
		.col-12.col-md-6 + .col-12.col-md-6 { margin-top: 20px; }
}

@media(max-width: 1024px){
	.section.section--halfs { padding-left: 15px; padding-right: 15px; }
}

/* ------------------------------------------------------------ *\
	Section Halfs Alt
\* ------------------------------------------------------------ */
.section--halfs--alt { padding-top: 20px; }


/* ------------------------------------------------------------ *\
		Section Full width background
\* ------------------------------------------------------------ */

.section-fw { margin: 44px 0 0; padding: 96px 0 95px; position: relative; }
.section-fw .section__bg { position: absolute; content: ''; height: 100%; top: 0; left: -50vw; right: -50vw; z-index: -1; }

.section-fw > * {  }
.section-fw h4 { line-height: 1.5; color: #fff; font-weight: normal; letter-spacing: -0.03em; }
.section-fw div[class^=col-] { flex: 0 1 900px; max-width: 900px; margin: 0 auto; padding-left: 15px !important; padding-right: 15px !important; }

/* Mobile */

@media( max-width: 767px ) {
	.section-fw { margin-top: 0; }
}

/* ------------------------------------------------------------ *\
		Section Columns
\* ------------------------------------------------------------ */

.section--columns { position: relative; padding: 50px 0; }
.section--columns .row:not(.section__head) { margin-left: -6px; margin-right: -6px; }
.section--columns .row:not(.section__head) div[class^=col-] { padding-left: 6px; padding-right: 6px; display: flex; flex-direction: column; }

.section--columns .section__head { text-align: center; padding: 8px 0; margin-bottom: 26px; }
.section--columns .section__head h2 { font-size: 40px; }

.section--columns .section__image { font-size: 14px; line-height: 1.78; margin-bottom: 28px; }
.section--columns .section__image-heading h4 { font-size: 22px; }
.section--columns .section__image .btn { bottom: 15px; white-space: nowrap; }
.section--columns .section__image-overlay { position: absolute; top: 0; bottom: 0; left: 0; right: 0; width: 100%; height: 100%; display: block; }

.section--columns .section__entry { min-height: 290px; position: relative; padding-bottom: 60px; flex: 1; }

.section--columns .section__entry h1,
.section--columns .section__entry h2,
.section--columns .section__entry h3,
.section--columns .section__entry h4,
.section--columns .section__entry h5,
.section--columns .section__entry h6 { letter-spacing: -0.05em; margin-bottom: 10px; }

.section--columns .section__entry h5 { margin-bottom: 7px; }
.section--columns .section__entry p { margin-bottom: 13px; }
.section--columns .section__entry .btn { font-size: 15px; padding: 5px 20px; position: absolute; bottom: 24px; left: 0; }

/* Tablet Portrait */

$breakpoint-tablet-portrait {
	.section--columns .section__head h2 { font-size: 32px; }
}

/* Mobile */

@media( max-width: 767px ) {
	.section--columns .section__entry { min-height: 200px; }
	.section--columns div[class^=col] p { margin-bottom: 15px; }
}

/* ------------------------------------------------------------ *\
		Section Background
\* ------------------------------------------------------------ */

.section .section__background { display: block; width: 100%; height: 100%; @extend imageCover; background-position: center; background-repeat: no-repeat; background-size: cover; }

.section.section--background { padding: 50px 0 20px; }
.section--background .col-12 h4 { font-size: 27px; font-weight: 400; margin-bottom: 20px; letter-spacing: 0.02em; }
.section--background .col-12 ul,
.section--background .col-12 ol { font-size: 15px; color: #000; }
.section--background .col-12  p { font-size: 15px; font-weight: 1.67; color: #000; }
.section--background .col-12 strong { font-weight: 900; }
.section--background .col-12:last-child { background: #f2f2fa; color: #fff; padding: 38px 35px 70px 38px; }
.section--background .row { font-size: 18.5px; padding-top: 15px; padding-bottom: 15px; }
.section--background .section__head { padding: 0 15px; }
/* ------------------------------------------------------------ *\
	Section Intro
\* ------------------------------------------------------------ */

.section-intro { background-color: #000; color: #fff; width: 100%; position: relative; padding: 0; min-height: 400px }
.section-intro .container { display: block !important; position: relative; z-index: 2; }

.section-intro .section__entry:before { position: absolute; content: ''; width: 100%; height: 100%; top: 0; right: 0; background-color: rgba(255,255,255,.2); background-color: rgba(18, 18, 23, .7); }
.section-intro .section__entry > * { position: relative; }
.section-intro .section__entry .entry { color: #fff; font-size: 20px; line-height: 1.56; font-weight: normal; letter-spacing: 0.005em; }
.section-intro .section__entry .entry > * { color: #fff; color: #fff; font-size: 45px; font-weight: 200; letter-spacing: -0.02em;  margin-left: 20px;  }

.section-intro h1 { font-size: 35px; font-weight: normal; color: #fff; }

.section.section-intro .section__image,
.section.section-intro .slider__slide-image { @extend imageFw; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-size: cover; background-repeat: no-repeat; background-position: center; }
.section.section-intro .row { padding: 0; }

.section-intro + *[class^=section] { margin-top: 50px; padding-top: 0;  }

.section-intro .section__inner,
.section-intro .slider__slide { min-height: 423px; max-height: 360px; padding: 20px 0; display: flex; align-items: center; position: relative; }

.section-intro .section__inner:after,
.section-intro .slider__slide:after { content: ''; min-height: inherit; font-size: 0; vertical-align: middle; }

.main .section.section-intro--default .section__image { position: relative; }
.section-intro--default + .article__meta { margin-top: 20px; }

.section.section-intro .slider-intro .container { position: absolute; bottom: 0; }
.section.section-intro .entry h1 { font-size: 30px; }
.section.section-intro .slider-intro .entry p { font-size: 20px; }
/* Tablet Portrait */

@media(max-width: 1023px){
	.section.section-intro { padding: 0; }
}

/* Mobile */

@media( max-width: 767px ) {
	.section-intro { min-height: 300px; }
	.section-intro + *[class^=section] { margin-top: 20px; padding-top: 0; }

	.section-intro .section__inner:after,
	.section-intro .slider__slide:after { display: none; }

	.section-intro .section__entry { flex: 0 1 100%; max-width: 100%; padding: 40px 15px; font-size: 17px; }

	.section-intro h1 { margin-bottom: 15px; font-size: 32px; }

	.section-intro .section__inner,
	.section-intro .slider__slide { min-height: 320px; padding: 30px 0; }

	.section-intro .section__entry .entry > * { font-size: 20px; }
	.section.section-intro .section__inner .section__entry { top: 0 !important; padding: 15px 30px; margin-top: 20px; }
	.section.section-intro .entry p { font-size: 18px!important;  margin-left: 0; }

}

/* ------------------------------------------------------------ *\
	Section Services
\* ------------------------------------------------------------ */

.section--halfs + .section-services { margin-top: -2px; }

.section-services { padding: 0 0 32px 0; }
.section-services .section__head h2 { font-size: 40px; color: #000; font-weight: 300; text-align: center; }
.section-services .service { text-align: center; }
.section-services .service a { text-decoration: none !important; }
.section-services .section__body { justify-content: center; }
.section-services .col { flex: 0 0 228px; max-width: 228px; padding-bottom: 23px; }

/* Tablet Portrait */

$breakpoint-tablet-portrait {
	.section-services .section__head h2 { font-size: 32px; }
}

/* ------------------------------------------------------------ *\
	Section CTA
\* ------------------------------------------------------------ */

.section-cta { position: relative; padding: 94px 0 74px; margin-bottom: -8px; color: #fff; }

.section-cta .row { width: 100%; justify-content: flex-end; }

.section-cta .section__background { padding: 0 !important; position: absolute; width: 100vw; height: 100% !important; margin-left: -50vw; top: 0; left: 50%; @extend imageCover; }

.section-cta .section__entry { text-align: right; }
.section-cta .section__entry h1 { font-size: 50px; font-weight: 700; line-height: 1.3; margin-bottom: 21px; color: #fff; }

.link-more { font-size: 19px; text-transform: uppercase; font-weight: 300; text-decoration: none !important; }
.link-more:hover { opacity: .65; }

@media(min-width: 1200px){
	.section-cta .section__entry { margin-right: -60px; }
}

/* Tablet Portrait */

$breakpoint-tablet-portrait {
	.section-cta { padding: 60px 0 !important; }
	.section-cta .section__entry { margin-right: -15px; }
}

/* Mobile */

@media( max-width: 767px ) {
	.section-cta .container { padding: 0; }
	.section-cta .section__entry { padding: 0; }
	.section-cta .section__inner { width: 100%; }
	.section-cta .section__entry h1 { font-size: 35px; }
}

/* ------------------------------------------------------------ *\
	Section Blog
\* ------------------------------------------------------------ */

.section--blog .section__head { margin-bottom: 60px; }
.section--blog .section__head h2 { font-size: 42px; color: #578463; }

/* Mobile */

@media( max-width: 767px ) {
	.section--blog .section__head h2 { font-size: 32px; }
}

/* ------------------------------------------------------------ *\
	Section Regular
\* ------------------------------------------------------------ */

.section--regular .section__head { text-align: center; }
.section--regular .section__head h2 { font-size: 42px; margin-bottom: 60px; }

.section--regular .section__image { margin: 0 auto 40px; }

.section--regular .section__entry p { margin-bottom: 20px; }
.section--regular .section__entry p.wp-caption-text { margin-bottom: 0; }
.section--regular .section__entry ul { list-style-type: disc; }

.section--regular .section__entry ol,
.section--regular .section__entry ul { margin-left: 25px; }

.section--regular .section__entry blockquote { border-left: 3px solid #58595b; padding-left: 15px; }

/* ------------------------------------------------------------ *\
	Section  Halfs Inner
\* ------------------------------------------------------------ */

.section-halfs-inner { position: relative; }
.section-halfs-inner .container { max-width: 1160px; display: block !important; }
.section-halfs-inner .section__inner { justify-content: flex-end; }
.section-halfs-inner .section__background { margin-bottom: 0; z-index: 0; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-size: cover; background-position: left; background-repeat: no-repeat; }

.section-halfs-inner .section__entry { position: relative; color: #fff; text-align: right; padding: 130px 15px 83px 15px; font-size: 30px; }
.section-halfs-inner .section__entry > * { position: relative; color: #000; }
.section-halfs-inner .section__entry-bg { position: absolute; content: ''; width: 100vw; height: 100%; top: 0; left: -85px; transform: skew(24deg); height: 100%;
background-color: color(green a(70%)); }

.section-halfs-inner h2 { font-size: 65px; margin-bottom: 99px; font-weight: normal !important; }

/* Tablet Portrait */

$breakpoint-tablet-portrait {
	.section-halfs-inner .section__entry { padding: 65px 15px; }
}

@media(max-width: 991px){
	.section-halfs-inner .section__entry { flex: 0 0 45%; max-width: 45%; }
	.section-halfs-inner h2 { margin-bottom: 40px; font-size: 50px; }
}

/* Mobile */

@media( max-width: 767px ) {
	.section-halfs-inner .section__entry { flex: 0 0 100%; max-width: 100%; font-size: 20px; padding: 50px 15px; text-align: left; padding: 22% 10% !important; }
	.section-halfs-inner h2 { margin-bottom: 40px; font-size: 35px; }
	.section-halfs-inner .section__entry-bg { transform: skew(0); left: 50%; top: 0; width: 100vw; height: 100%; margin-left: -50vw; }
	.section-halfs-inner .section__entry-bg.bg-image { display: none; }
}



/* ------------------------------------------------------------ *\
	Section CTA Secondary
\* ------------------------------------------------------------ */

.section-cta-secondary { position: relative; color: #fff; padding: 58px 0 49px; }
.section-cta-secondary .section__background { position: absolute; content: ''; left: 50%; top: 1; width: 100vw; height: 100%; margin-left: -50vw; z-index: 1; background-size: cover;
		background-position: center center; background-repeat: no-repeat; }
.section-cta-secondary .container { position: relative; z-index: 2; display: block !important; }
.section-cta-secondary .section__entry { color: #fff; }
.section-cta-secondary .section__entry strong { font-weight: 600; }
.section-cta-secondary .section__entry a { text-decoration: none; }
.section-cta-secondary .section__entry h4 { font-size: 35px; margin: 0 0 20px 0; }

.section-cta-secondary .section__entry h1,
.section-cta-secondary .section__entry h2,
.section-cta-secondary .section__entry h3,
.section-cta-secondary .section__entry h4,
.section-cta-secondary .section__entry h5,
.section-cta-secondary .section__entry h6 { font-weight: 300; margin-bottom: 22px; line-height: 1.42; color: #fff; }

.section-cta-secondary .section__entry h6 { font-size: 27px; }
.section-cta-secondary .section__entry a:not([class]) { text-decoration: none; }
.section-cta-secondary .section__entry a:not([class]):hover { opacity: .7; }

/* Mobile */

@media( max-width: 767px ) {
	.section-cta-secondary { padding: 35px 0; }
	.section-cta-secondary .section__entry h1,
	.section-cta-secondary .section__entry h2,
	.section-cta-secondary .section__entry h3,
	.section-cta-secondary .section__entry h4,
	.section-cta-secondary .section__entry h5,
	.section-cta-secondary .section__entry h6 { margin-bottom: 18px; }

	.section-cta-secondary .section__entry h6 { font-size: 20px; }
	.section-cta-secondary .section__entry h6:last-child { margin-bottom: 0; }
}

/* ------------------------------------------------------------ *\
	Section Results
\* ------------------------------------------------------------ */

.section-results { padding: 100px 0; margin-left: -10px; margin-right: -10px; }
.section-results .container { display: block !important;  }
.section-results .section__inner > h3 { margin-bottom: 26px; }

/* Tablet Portrait */

$breakpoint-tablet-portrait {
	.section-results { padding: 50px 0; }
}

/* ------------------------------------------------------------ *\
	Section Not Found
\* ------------------------------------------------------------ */

.section--not-found { padding: 200px 0 200px; text-align: center; }

.section--not-found .section__head { margin-bottom: 50px; color: #000; }
.section--not-found .section__content { margin-bottom: 50px; color: #000; }
.section--not-found .section__content p { line-height: 1.5; }
.section--not-found .section__content a { text-decoration: none; }
.section--not-found .section__content a:hover { text-decoration: underline; }

$breakpoint-tablet-portrait {
	.section--not-found { padding: 120px 0 80px; }
}

@media( max-width: 767px ) {

	.section--not-found .section__head { margin-bottom: 30px; }
	.section--not-found .section__content { margin-bottom: 30px; }

}

/* ------------------------------------------------------------ *\
		Section
\* ------------------------------------------------------------ */

/* Tablet Portrait */

$breakpoint-tablet-portrait {
	.section { padding: 20px 0; }
}


@media( max-width: 767px ) {
	.section .row {  }

	.section .section__head { margin-bottom: 0; }

	.section .section__background { height: 0; padding-top: 100%; }

	.section--background .col-12 { margin-bottom: 0; }
	.section--background .col-12:last-child { padding: 15px; }

	.section .section__image .btn { bottom: 10px; }
}

/* ------------------------------------------------------------ *\
	Section Fullwidth
\* ------------------------------------------------------------ */
.section--fullwidth .section__image .section__image-heading > * { text-align: left; font-size: 45px; font-weight: 200; letter-spacing: -0.02em;  }

/* Mobile */

@media( max-width: 767px ) {
	.section--fullwidth .section__image .section__image-heading > * { font-size: 20px; }
}


/* ------------------------------------------------------------ *\
	Section Full Width Alt
\* ------------------------------------------------------------ */

.section--fullwidth--alt { padding: 0; }
.section--fullwidth--alt .row { padding-top: 0; }



/* ------------------------------------------------------------ *\
	Section Main
\* ------------------------------------------------------------ */
/*.section-main { padding: 100px 0; }*/
.section-main .container {max-width: 1028px; padding: 0 15px; }
.section-main .content { flex: 1; }
.section-main .sidebar { flex: 0 0 280px; max-width: 280px; margin-left: 25px; flex-shrink: 0; padding: 10px 15px 0; color: #000; }
.section-main .sidebar h2 { font-size: 1.6rem; }
.section-main .sidebar a:hover { text-decoration: underline; }
.section-main ol,
.section-main ul { list-style-position: inside; }
.section-main a:not([class]) { color: inherit; text-decoration: underline; }
.section-main a:not([class]):hover { text-decoration: none; }
.section-main blockquote { padding: 15px 0 15px 20px; border-left: 2px solid #000; font-style: italic; }
/* With Sidebar */
.section-main--sidebar .section-intro { width: 100%; margin-left: 0; left: 0; overflow: hidden; }
.section-main--sidebar .section-intro .section__entry { margin-left: 40px; }
.section-main--sidebar .content { flex: 0 0 calc(100% - 280px); max-width: calc(100% - 280px); }
.section-main--sidebar .widgets > li { width: 100%; }
.section-main h1,
.section-main h2,
.section-main h3,
.section-main h4,
.section-main h5,
.section-main h6 { color: #2280c8; font-weight: 600; }
/* Tablet Portrait */
$breakpoint-tablet-portrait {
	.section-main--sidebar .container { flex-wrap: wrap; }
	.section-main--sidebar .sidebar,
	.section-main--sidebar .content { flex: 0 0 100%; max-width: 100%; }
	.section-main--sidebar .sidebar { flex: 0 0 100%; max-width: 100%; margin: 0; padding: 0 0 30px 0; }
}
/* Mobile */
@media( max-width: 767px ) {
	.section-main--sidebar .sidebar { text-align: center; }
	.section-main--sidebar .section-intro .section__entry { margin: 0 15px; }
}

/* ------------------------------------------------------------ *\
	Main
\* ------------------------------------------------------------ */

body.error404 .main { display: flex; flex-wrap: wrap; }
body.error404 .main > section { width: 100%; }

@media(max-width: 1024px){
	.section-main .container { padding-left: 0; padding-right: 0; }
}


/* ------------------------------------------------------------ *\
	Section Features
\* ------------------------------------------------------------ */
.section-features .feature { position: relative; }
.section-features .feature__image { min-height: 200px; }
.section-features .feature__body { position: relative; }

.nav-trigger { position: relative; display: inline-block; width: 23px; height: 23px; }
.nav-trigger span { position: absolute; display: block; height: 3px; width: 100%; border-radius: 4px; background: #fff; transition: top .2s .25s, opacity .2s .25s, transform .2s 0s; }

.nav-trigger span:nth-child(1) { top: 0; }
.nav-trigger span:nth-child(2) { top: 10px; }
.nav-trigger span:nth-child(3) { top: 20px; }

.nav-trigger--active span { transition: background .2s, top .2s, opacity .2s, transform .2s .25s; }

.nav-trigger--active span:nth-child(3),
.nav-trigger--active span:nth-child(1) { top: 10px; }

.nav-trigger--active span:nth-child(2) { opacity: 0; }
.nav-trigger--active span:nth-child(1) { transform: rotate(45deg); }
.nav-trigger--active span:nth-child(3) { transform: rotate(-45deg); }
