/* ------------------------------------------------------------ *\
	Base
\* ------------------------------------------------------------ */

@media (max-width: 767px) {
	* { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
	body { min-width: 320px; }
	.shell { width: 100%; padding: 0 20px; }	
}

/* ------------------------------------------------------------ *\
	Icons
\* ------------------------------------------------------------ */

@media (max-width: 767px) {
	.ico-tube { width: 61px; height: 73px; background: url(images/icons/ico-tube.png) no-repeat 0 0; }
	.ico-tech { width: 63px; height: 79px; background: url(images/icons/ico-tech.png) no-repeat 0 0; }
	.ico-tech2 { width: 97px; height: 60px; background: url(images/icons/ico-tech2.png) no-repeat 0 0; }
	.ico-islands { width: 46px; height: 43px; background: url(images/icons/ico-islands.png) no-repeat 0 0; }
}

/* ------------------------------------------------------------ *\
	Header
\* ------------------------------------------------------------ */

.header .navbar-toggle { display: none; }

@media (max-width: 767px) {
	.header { box-shadow: none; overflow: visible; }
	.header .header-inner { float: none; }
	.header .shell { padding: 0 18px; }
	.header .logo { width: 150px; height: 52px; float: none; display: inline-block; position: relative; z-index: 999; }	

	.header-actions { padding: 0; position: absolute; top: 50%; right: 50px; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); -o-transform: translateY(-50%); transform: translateY(-50%); }
	.header .btn { font-size: 11px; padding: 8px 21px 5px; }	

	.header .navbar-toggle { display: block; width: 26px; padding: 8px 4px; position: absolute; right: 14px; top: 50%; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); -o-transform: translateY(-50%); transform: translateY(-50%);  z-index: 999; }	

	.header .navbar-toggle .bar1,
	.header .navbar-toggle .bar2,
	.header .navbar-toggle .bar3 { display: block; height: 2px; background-color: #667684; position: relative; top: 0; opacity: 1; -webkit-transition: all .4s ease; -o-transition: all .4s ease; transition: all .4s ease; }	

	.header .navbar-toggle .bar2,
	.header .navbar-toggle .bar3 { margin-top: 3px; }

	.header .navbar-toggle.navbar-on .bar1 { -webkit-transform: rotate(45deg); -ms-transform: rotate(45deg); -o-transform: rotate(45deg); transform: rotate(45deg); top: 5px; }
	.header .navbar-toggle.navbar-on .bar2 { opacity: 0; }
	.header .navbar-toggle.navbar-on .bar3 { -webkit-transform: rotate(-45deg); -ms-transform: rotate(-45deg); -o-transform: rotate(-45deg); transform: rotate(-45deg); top: -5px; }
}

@media (max-width: 374px) {
	.header .logo { width: 120px; height: 41px; margin-top: 20px; -webkit-background-size: 100% auto; background-size: 100% auto; }
}

/* ------------------------------------------------------------ *\
	Navbar Nav
\* ------------------------------------------------------------ */

@media (max-width: 767px) {

	.nav { width: 100%; height: 100%; position: fixed; left: 0; top: 0; opacity: 0; visibility: hidden; background: rgba(255, 255, 255, .98); z-index: 998; padding-top: 100px; text-align: center; -webkit-transition: opacity .4s ease, visibility .4s ease; -o-transition: opacity .4s ease, visibility .4s ease; transition: opacity .4s ease, visibility .4s ease; }
	.nav.active { opacity: 1; visibility: visible; }

	.nav li { float: none; display: block; }
	.nav a { font-size: 14px; color: #667684; text-transform: uppercase; letter-spacing: 0.1em; border: 0; padding: 20px 0; }

	.nav a:hover,
	.nav a:focus,
	.nav a:active { border: 0; color: #7bbe41; background-color: transparent; }

}

/* ------------------------------------------------------------ *\
	Intro
\* ------------------------------------------------------------ */

.intro-slider { display: none; }

@media (max-width: 767px) {

	.intro { height: auto; padding: 40px 0 0; background: url(images/intro-bg-mobile.jpg) no-repeat center; -webkit-background-size: cover; background-size: cover; }

	.intro-slider { display: block; }
	.intro-image { display: none; }

	.intro-title { font-size: 34px; margin: 0 -5px 10px; }

	.intro-entry { padding: 0; }
	.intro-entry p { font-size: 14px; }

	.intro .intro-actions { padding-bottom: 45px; }
	.intro .intro-actions .btn { min-width: 250px; font-size: 13px; letter-spacing: 0.222em; padding: 19px 25px 18px; }

}

/* ------------------------------------------------------------ *\
	Sliders
\* ------------------------------------------------------------ */

@media (max-width: 767px) {

	.slider-intro { text-align: center; margin: 0 -20px 15px; position: relative; }
	.slider-intro .owl-item { -webkit-backface-visibility: visible; }

	.slider-intro .slide-image img { display: inline-block; width: 150px; height: auto; -webkit-transform: scale(.8); -ms-transform: scale(.8); -o-transform: scale(.8); transform: scale(.8); opacity: .5; -webkit-transition: all .6s ease; -o-transition: all .6s ease; transition: all .6s ease; }
	.slider-intro .slide-image span { position: static; display: block; font-family: 'Brandon Bold', sans-serif; font-size: 16px; padding-top: 20px; opacity: .5; -webkit-transition: all .6s ease; -o-transition: all .6s ease; transition: all .6s ease; }

	.slider-intro .active .slide-image img { -webkit-transform: scale(1); -ms-transform: scale(1); -o-transform: scale(1); transform: scale(1); opacity: 1; }
	.slider-intro .active .slide-image span { opacity: 1; }

	.slider-intro .owl-prev,
	.slider-intro .owl-next { font-size: 0; position: absolute; bottom: 26px; }

	.slider-intro .owl-prev { margin-left: 10px; width: 22px; height: 15px; background: url(images/icons/ico-arrow-prev@2x.png) no-repeat 0 0; -webkit-background-size: 22px 15px; background-size: 22px 15px; }
	.slider-intro .owl-next { margin-right: 10px; width: 22px; height: 15px; background: url(images/icons/ico-arrow-next@2x.png) no-repeat 0 0; -webkit-background-size: 22px 15px; background-size: 22px 15px; }

}

/* ------------------------------------------------------------ *\
	Sections
\* ------------------------------------------------------------ */

.section-stewie .section-image img.desktop { display: block; }
.section-stewie .section-image img.mobile { display: none; }

.feature-content { position: relative; padding: 16px 0 0 110px; }
.feature-image { float: none; position: absolute; left: 0; top: 0; }

.section-machine .section-image img.desktop { display: block; }
.section-machine .section-image img.mobile { display: none; }

.section-coin .section-image img.desktop { display: block; }
.section-coin .section-image img.mobile { display: none; }

.process-content .mobile-img { display: none; }

.section-humans .article-entry .branding { margin: 10px 0 20px; }

@media (max-width: 767px) {

	.section-reality { padding-bottom: 75px; }
	.section-reality .section-head h1 { font-size: 37px; }
	.section-reality .section-title:before { width: 50px; margin: 0 auto; }

	.section-marketing { padding-bottom: 23px; box-shadow: inset 0 -5px 10px rgba(0,0,0, .05); }
	.section-marketing .ico-speaker { -webkit-transform: scale(.75); -ms-transform: scale(.75); -o-transform: scale(.75); transform: scale(.75); margin: -53px 0 -4px; }

	.section-marketing .section-head { background: url(images/section-marketing-head-bg.png) no-repeat center; -webkit-background-size: cover; background-size: cover; padding-bottom: 0; }
	.section-marketing .section-head p { font-size: 16px; }
	.section-marketing .section-head p strong { display: block; font-size: 18px; padding-top: 5px; }

	.section-marketing .section-body .box { width: 100%; height: auto; padding: 20px 0; border: 0; position: relative; bottom: 0; left: 0; top: 0; margin: 0; background-color: transparent; }
	.section-marketing .section-body .box p { font-family: 'Brandon Light', sans-serif; font-size: 23px; color: #444; line-height: 1.2; padding: 0 30px; }
	.section-marketing .section-body .box .box-inner { width: 100%; height: auto; position: relative; left: 0; top: 0;  border: 0; padding: 0; background-color: transparent; }

	.section-marketing .shell { width: 100%; min-width: 100%; padding: 0 20px; }
	.section-marketing .section-head .shell { padding: 0 10px; }

	.marketing-items,
	.marketing-item { display: block; }

	.marketing-item { width: 100%; padding: 0; border: 1px solid #e5e4e4; border-radius: 3px; }
	.marketing-item-inner { box-shadow: none; height: auto; padding: 130px 20px 40px; position: relative; }
	.marketing-item-inner i { position: absolute; left: 50%; top: 55px; -webkit-transform: translateX(-50%); -ms-transform: translateX(-50%); -o-transform: translateX(-50%); transform: translateX(-50%); }
	.marketing-item-inner p { font-size: 17px; color: #7d7d7d; line-height: 1.4; letter-spacing: 0.017em; }
	.marketing-item ~ .marketing-item { margin-top: 12px; }

	.marketing-item-gray .marketing-item-inner,
	.marketing-item-green .marketing-item-inner,
	.marketing-item-dark-green .marketing-item-inner { background: transparent; }

	.marketing-item-gray .marketing-item-inner { padding: 120px 40px 40px; }

	.marketing-item-gray .marketing-item-inner:before { content: ''; width: 118px; height: 154px; background: url(images/icons/ico-tube-large@2x.png) no-repeat 0 0; -webkit-background-size: 118px 154px; background-size: 118px 154px; position: absolute; left: 0; top: 0; z-index: 1; }

	.marketing-item-green .marketing-item-inner:before { content: ''; width: 121px; height: 154px; background: url(images/icons/ico-tech-large@2x.png) no-repeat 0 0; -webkit-background-size: 121px 154px; background-size: 121px 154px; position: absolute; left: 0; top: 0; z-index: 1; }

	.marketing-item-dark-green .marketing-item-inner:before { content: ''; width: 128px; height: 118px; background: url(images/icons/ico-tech2-large@2x.png) no-repeat 0 0; -webkit-background-size: 128px 118px; background-size: 128px 118px; position: absolute; left: 0; top: 0; z-index: 1; }


	.section-stewie { background-color: #fff; border-top: 1px solid #cdcdcd; }
	.section-stewie .section-head h1 { font-size: 38px; }
	.section-stewie .section-title:before { width: 50px; margin: 0 auto 10px; }

	.section-stewie .section-content,
	.section-stewie .section-image { float: none; width: 100%; }
	
	.section-stewie .section-body { -webkit-display: flex; display: flex; -webkit- flex-direction: column-reverse; flex-direction: column-reverse; }

	.section-stewie .section-image { margin-bottom: 30px; }
	.section-stewie .section-image img.desktop { display: none; }
	.section-stewie .section-image img.mobile { display: block; }
	.section-stewie .section-image img { width: 100%; height: auto; }

	.feature { position: relative; text-align: center; }
	.feature-image { float: none; padding: 10px 0; position: relative; }
	.feature-content { padding: 0; }
	.feature-entry p { font-size: 17px; color: #7d7d7d; }
	.feature-title { padding: 0 20px 0; }
	.feature ~ .feature .feature-title:before { content: ''; display: block; width: 25px; height: 2px; background-color: #93be4c; margin: 0 auto 20px; }

	.section-machine .shell { padding: 0; }
	.section-machine .ico-greenlamp-big { -webkit-transform: scale(.6); -ms-transform: scale(.6); -o-transform: scale(.6); transform: scale(.6); margin: -45px 0 10px; }
	.section-machine .section-head { padding-bottom: 30px; }
	.section-machine .section-title { font-size: 37px; }
	.section-machine .section-title:before { width: 50px; }
	.section-machine .section-body { max-width: 375px; margin: 0 auto; }
	.section-machine .section-body:after { content: ''; display: table; clear: both; }
	.section-machine .section-content { width: 60%; padding-top: 40px; margin-left: 0; padding-left: 25px; }
	.section-machine .section-content ul li { font-weight: 300; font-size: 12px; line-height: 1.5; }
	.section-machine .section-content ul li ~ li { padding-top: 40px; }
	.section-machine .section-content ul li strong { font-weight: 600; }
	.section-machine .section-image { width: 40%; margin-right: 0; }
	.section-machine .section-image img { width: 100%; height: auto; }
	.section-machine .section-image img.desktop { display: none; }
	.section-machine .section-image img.mobile { display: block; }
	.section-machine .section-actions { display: none; }

	.section-coin .shell { padding: 0; }
	.section-coin .ico-greenlamp-big { -webkit-transform: scale(.6); -ms-transform: scale(.6); -o-transform: scale(.6); transform: scale(.6); margin: -45px 0 10px; }
	.section-coin .section-head { padding-bottom: 30px; }
	.section-coin .section-title { font-size: 37px; }
	.section-coin .section-title:before { width: 50px; }
	.section-coin .section-body { max-width: 375px; margin: 0 auto; }
	.section-coin .section-body:after { content: ''; display: table; clear: both; }
	.section-coin .section-content { width: 60%; padding-top: 40px; margin-left: 0; padding-left: 25px; }
	.section-coin .section-content ul li { font-weight: 300; font-size: 12px; line-height: 1.5; }
	.section-coin .section-content ul li ~ li { padding-top: 40px; }
	.section-coin .section-content ul li strong { font-weight: 600; }
	.section-coin .section-image { width: 40%; margin-right: 0; }
	.section-coin .section-image img { width: 100%; height: auto; }
	.section-coin .section-image img.desktop { display: none; }
	.section-coin .section-image img.mobile { display: block; }
	.section-coin .section-actions { display: none; }

	.section-process { padding: 40px 0; }
	.section-process .section-head { padding-bottom: 30px; }
	.section-process .section-head h1 { font-size: 37px; }
	.section-process .section-title:before { width: 50px; }

	.processes { background: none; padding: 0 20px; }

	.process { padding: 0; }
	.process ~ .process { position: relative; }
	.process ~ .process:before { content: ''; display: block; width: 25px; height: 2px; background-color: #93be4c; margin: 0 auto 20px; }

	.process-content { padding-top: 0; float: none; width: 100%; text-align: center; }
	.process-content .mobile-img { display: inline-block; width: 165px; margin: 10px auto 30px; padding: 4px; border: 1px solid #ccc; border-radius: 50%; }
	.process-content h2 { font-size: 30px; padding: 20px 0; }
	.process-number { display: inline-block; position: relative; left: 0; top: 0; margin: 0; }
	.process-entry p { font-weight: 300; font-size: 15px; color: #858585; line-height: 1.8; }

	.process-image { display: none; }

	.process-alt .process-content { float: none; margin: 0; }
	.process-alt .process-image { float: none; }

	.section-humans { background: url(images/section-coin-mobile.jpg) no-repeat center; -webkit-background-size: cover; background-size: cover; padding: 35px 0; box-shadow: 0 5px 10px rgba(0,0,0, .25); position: relative; }

	.section-humans .section-head span { font-family: 'Brandon', sans-serif; font-size: 13px; margin-top: 15px; }
	.section-humans .section-head span:before { display: none; }

	.section-humans .section-title { font-size: 37px; }
	.section-humans .section-title:after { height: 2px; margin: 10px auto 0; }

	.section-humans .article-title { font-family: 'Brandon', sans-serif; font-size: 21px; text-transform: uppercase; line-height: 1.9; }
	.section-humans .article-entry p { font-weight: 300; font-size: 15px; line-height: 1.8; }

	.section-privacy { padding: 0 0 50px; }
	.section-privacy .section-head { padding-bottom: 20px; }
	.section-privacy .section-body p { padding-bottom: 0; }

	.list-bullets { padding: 20px 0 0 25px; }
	.list-bullets a { word-break: break-all; }
}

@media (max-width: 374px) {
	.section-machine .section-content,
	.section-machine .section-content ul li ~ li { padding-top: 20px; }
}

/* ------------------------------------------------------------ *\
	Tabs
\* ------------------------------------------------------------ */

@media (max-width: 767px) {

	.tabs-nav { position: relative; }
	.tabs-nav ol { padding: 10px 0 0; border: 0; }
	.tabs-nav li { width: 50%; padding-top: 30px; padding-bottom: 30px; border-bottom: 1px solid #e8e8e8; }
	.tabs-nav li:nth-child(odd) { border-right: 1px solid #e8e8e8; }
	.tabs-nav li:nth-child(n+3) { padding-top: 60px; }

	.tabs-nav li:last-child,
	.tabs-nav li:nth-last-child(2) { border-bottom: 0; }

	.tabs-nav li:nth-child(1) .service-number { left: 16px !important; }
	.tabs-nav li:nth-child(2) .service-number { left: 20px !important; }
	.tabs-nav li:nth-child(3) .service-number { left: 17px !important; }
	.tabs-nav li:nth-child(4) .service-number { left: 15px !important; }
	.tabs-nav li:nth-child(5) .service-number { left: 20px !important; }

	.tabs-nav .slide-line { display: none; }

	.tabs .tab.current { display: none; }

	.service-image { padding-bottom: 0; }
	.service-number { top: -22px; }

}

@media (max-width: 374px) {
	.service-title { font-size: 16px; }
}

/* ------------------------------------------------------------ *\
	Modal
\* ------------------------------------------------------------ */

.modal-overlay { width: 100%; height: 100%; background-color: rgba(0,0,0, .75); position: fixed; left: 0; top: 0; z-index: 999; opacity: 0; visibility: hidden; -webkit-transition: opacity .4s ease, visibility .4s ease; -o-transition: opacity .4s ease, visibility .4s ease; transition: opacity .4s ease, visibility .4s ease; }
.modal-container { width: 90%; max-height: 94%; background-color: #fff; border-radius: 10px; position: absolute; left: 5%; top: 20px; z-index: 1000; box-shadow: 0 0 16px rgba(0,0,0, .2); overflow-y: auto; overflow-x: hidden; opacity: 0; visibility: hidden; -webkit-transition: opacity .4s ease, visibility .4s ease; -o-transition: opacity .4s ease, visibility .4s ease; transition: opacity .4s ease, visibility .4s ease; }

.modal-visible.modal-overlay,
.modal-visible .modal-container { opacity: 1; visibility: visible; }

.modal-container { text-align: center; padding: 35px; }
.modal-container img { height: 70px; width: auto; }
.modal-container strong { font-family: 'Brandon Light', sans-serif; font-size: 34px; text-transform: none; color: #333; letter-spacing: -0.01em; line-height: 1; margin: 0 0 20px; }
.modal-container p { margin: 0; font-weight: 300; font-size: 19px; color: #7d7d7d; line-height: 1.35; }
.modal-container .modal-close-button { position: absolute; right: 35px; top: 25px; border: 0; background-color: transparent; z-index: 1000; }

.modal-container .modal-close-button:before,
.modal-container .modal-close-button:after { content: ''; width: 24px; height: 1px; background-color: #73818e; position: absolute; left: 0; }

.modal-container .modal-close-button:before { -webkit-transform: rotate(45deg); -ms-transform: rotate(45deg); -o-transform: rotate(45deg); transform: rotate(45deg); top: 0; }
.modal-container .modal-close-button:after { -webkit-transform: rotate(-45deg); -ms-transform: rotate(-45deg); -o-transform: rotate(-45deg); transform: rotate(-45deg); top: 0px; }

/* ------------------------------------------------------------ *\
	Footer
\* ------------------------------------------------------------ */

.footer-cols { position: relative; }

@media (max-width: 767px) {

	.footer .shell { padding: 0 33px; }
	.footer-cols { margin: 0; }
	.footer-col { width: 100% !important; min-height: 0; }
	.footer-col ~ .footer-col { padding-left: 0; }

	.footer-title { text-align: center; }
	.footer-title:after { display: block; width: 25px; margin: 0 auto; position: static; background-color: #8dc63f; }
	.footer-title:before { display: none; }

	.footer-nav { margin-right: -30px; }
	.footer-nav ul { width: 50%; padding-left: 15px; }
	.footer-nav li { padding-left: 0; }

	.footer-nav li:before,
	.footer-nav li + li:after { display: none; }

	.footer-col:first-child { padding-bottom: 30px; }

	.footer .jobs { text-align: center; padding: 0 20px; }
	.footer .jobs p { letter-spacing: 0.04em; }
	.footer .jobs .jobs-actions { margin-bottom: 50px; }
	.footer .jobs .jobs-actions a { font-family: 'Brandon Bold', sans-serif; letter-spacing: 0.222em; padding: 0 20px 0 15px; }

	.footer .form-head { text-align: center; letter-spacing: 0.04em; }

	.footer .form .field,
	.footer .form .textarea { width: 100%; }

	.footer .form .btn-green { width: 100%; font-family: 'Brandon Bold', sans-serif; font-size: 13px; letter-spacing: 0.222em; border-radius: 5px; }

	.footer-logo { width: 128px; height: auto; position: relative; left: 0; margin: 0 auto 30px; background: none; text-indent: 0; padding-top: 50px; }
	.footer-logo img { width: 128px; height: auto; }

	.footer .socials { position: static; margin: 0 auto 30px; text-align: center; }
	.footer .socials li { float: none; display: inline-block; vertical-align: middle; }

}

@media (max-width: 374px) {
	.footer .jobs { padding: 0; }
}
