/* ================================================================================== */
/* == Normalize.css v7.0.0 ========================================================== */
/* ================================================================================== */

html{line-height:1.15;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}article,aside,footer,header,nav,section{display:block}h1{font-size:2em;margin:0.67em 0}figcaption,figure,main{display:block}figure{margin:1em 40px}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace, monospace;font-size:1em}a{background-color:transparent;-webkit-text-decoration-skip:objects}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:inherit}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em}dfn{font-style:italic}mark{background-color:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}audio,video{display:inline-block}audio:not([controls]){display:none;height:0}img{border-style:none}svg:not(:root){overflow:hidden}button,input,optgroup,select,textarea{font-family:sans-serif;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}button,html [type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{display:inline-block;vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px}[type="search"]::-webkit-search-cancel-button,[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details,menu{display:block}summary{display:list-item}canvas{display:inline-block}template{display:none}[hidden]{display:none}

*,*:before,*:after { box-sizing: border-box; margin: 0; padding: 0; list-style: none }

/* Viewport Sizing */
@-webkit-viewport{width:device-width}
@-moz-viewport{width:device-width}
@-ms-viewport{width:device-width}
@-o-viewport{width:device-width}
@viewport{width:device-width}


/* ================================================================================== */
/* == Variables ===================================================================== */
/* ================================================================================== */

:root { 
	--darkest-text: #24262C;
	--default-text: #737373;
	--lightest-text: #9EA4AE;
	
	--color-primary: #D7272A;
	--color-primary-alt: #F24247;
	--color-dark: #18191B;
	
	--padding: 70px;
}

@media only screen and (max-width: 730px) {
	:root { 
		--padding: 55px;
	}
}
@media only screen and (max-width: 500px) {
	:root { 
		--padding: 40px;
	}
}
@media only screen and (max-width: 380px) {
	:root { 
		--padding: 30px;
	}
}

@media only screen and (max-width: 320px) {
	:root { 
		--padding: 25px;
	}
}



/* ================================================================================== */
/* == General Styles ================================================================ */
/* ================================================================================== */

html,body { background: #fff; font-family: "proxima-nova", sans-serif; color: var(--default-text); font-size: 16px; line-height: 1.4; }
.container { max-width: 1200px; padding: 0 var(--padding); margin: 0 auto; position: relative; }
.container:after { content: ""; display: table; clear: both; }

a { text-decoration: none; color: var(--color-primary); transition: all 0.218s; }
a:hover {  }

p { margin-bottom: 1em; }
h1, h2, h3, h4 { margin-bottom: 1em; font-family: "rift", sans-serif; font-style: italic; color: var(--darkest-text); }
h2 { font-size: 3.5rem; margin-top: -0.15em; margin-bottom: 1.5rem; line-height: 1; }

section { position: relative; }


@media only screen and (max-width: 500px) {
	html,body { font-size: 15px; }
	h2 { margin-top: -0.1em; text-align: center;}
}
@media only screen and (max-width: 380px) {
	h2 { font-size: 3rem; }
}
@media only screen and (max-width: 320px) {
	h2 { font-size: 2.5rem; }
}



/* ================================================================================== */
/* == Header ======================================================================== */
/* ================================================================================== */

#header { background: var(--color-dark); width: 100%; z-index: 99; border-bottom: 1px solid rgba(255,255,255,0.1); }
#header .container {  }
#header .logo { float: left; background: url(../img/skull-logo.png) no-repeat left; height: 80px; background-size: auto 65%; padding-left: 80px; font-size: 2.55em; line-height: 80px; font-family: "rift", sans-serif; font-style: italic; font-weight: bold; color: #fff; }
#header .logo em { color: var(--color-primary); }


/*Navigation*/
#main-nav { float: right; }
#main-nav ul { overflow: hidden; margin: 0; }
#main-nav ul li { float: left; }
#main-nav ul li a { display: block; padding: 0 20px; line-height: 80px; color: rgba(255,255,255,0.75); }
#main-nav ul li a:hover { color: #fff; }
#main-nav ul li a.try { background: var(--color-primary); line-height: 44px; font-weight: bold; color: #fff; border-radius: 4px; margin-top: 18px; margin-left: 15px; text-shadow: 0 1px 2px rgba(0,0,0,0.3); }

.menu-open { position: absolute; top: 17px; right: 17px; background: rgba(255,255,255,0.1) url(../img/icon-menu.svg) no-repeat 70px center; background-size: 30px; height: 46px; line-height: 46px; color: #fff; padding: 0 51px 0 15px; font-weight: bold; text-transform: uppercase; border-radius: 2px; box-shadow: 0 2px 4px rgba(0,0,0,0.25), inset 0 5px 15px rgba(255,255,255,0.05), inset 0 -5px 15px rgba(0,0,0,0.15); opacity: 0.95; cursor: pointer; display: none; }
#main-nav .menu-close { position: absolute; top: 10px; right: 10px; width: 50px; height: 50px; text-indent: -9999px; background: url(../img/icon-close.svg) no-repeat center; background-size: 80%; opacity: 0.75; cursor: pointer; display: none; }

#main-nav.open { display: block; }

@media only screen and (max-width: 1000px) {
	#header .container { padding: 0 17px; }
}
@media only screen and (max-width: 900px) {
	#header .container { padding: 0; }
	#header .logo { margin-left: 17px; }
	#main-nav { position: fixed; top: 0; left: 0; width: 100%; height: 100vh; background: var(--color-dark); text-align: center; opacity: 0.98; font-size: 5vh; transform-style: preserve-3d; display: none; z-index: 999;}
	#main-nav ul { position: relative; top: 45%; transform: translateY(-50%); }
	#main-nav ul li { float: none; margin: 0; }
	#main-nav ul li a { line-height: 3; }
	#main-nav ul li a.try { margin: 1em 0 0 0; display: inline-block; line-height: 3; padding: 0 1.25em; }
	.menu-open,
	#main-nav .menu-close { display: block; }
}
@media only screen and (max-width: 540px) {
	#header .logo { background-size: auto 53%; padding-left: 65px; font-size: 2.25em; }
	.menu-open { text-indent: -9999px; padding: 0; width: 50px; box-shadow: none; background: url(../img/icon-menu.svg) no-repeat center center; background-size: 36px; opacity: 0.75; }
}
@media only screen and (max-width: 430px) {
	/*.menu-open { text-indent: -9999px; padding: 0; width: 50px; background-position: center; }*/
	#header .logo { background-size: auto 41%; padding-left: 50px; font-size: 2.1em; }
	.menu-open { width: 44px; }
}
@media only screen and (max-width: 480px) {
	#header .logo { background-size: auto 39%; padding-left: 36px; font-size: 2em; line-height: 62px; height: 62px; }
	.menu-open { width: 40px; top: 8px; right: 10px; }
}
@media only screen and (max-width: 320px) {
	#header .logo { background: none; padding-left: 0; }
}



/* ================================================================================== */
/* == Intro ========================================================================= */
/* ================================================================================== */

.intro { background: var(--color-dark);  color: #fff; }
.intro .container { position: absolute; top: 0; left: calc((100vw - 1200px) / 2); width: 100%; height: 100%; z-index: 1; }
.intro h1 { margin: 0; color: #fff; font-size: 6em; text-shadow: 0px 2px 6px rgba(0,0,0,0.7), 0px 1px 15px rgba(0,0,0,0.15), 0px 4px 25px rgba(0,0,0,0.3); line-height: 1; }
.intro h1 span { color: rgba(255,255,255,0.85); font-size: 0.85em; vertical-align: 0.03em; }
.intro h2 { display: inline-block; margin: 5px 0 0 0; color: #fff; font-size: 2em; font-style: normal; background: var(--color-primary); padding: 0.25em .5em; text-shadow: 1px 2px 0px rgba(0,0,0,0.4); }
.intro .text { position: absolute; top: 50%; transform: translateY(-50%); }
  
.intro .try-button { background: var(--color-primary); color: #fff; position: absolute; height: 100px; width: 100px; border-radius: 50%; text-align: center; font-family: "rift", sans-serif; font-weight: bold;  }

@media only screen and (max-width: 1200px) {
	.intro .container { left: 0; }
}
@media only screen and (max-width: 1000px) {
	.intro h1 { font-size: 8vw; }
	.intro h2 { font-size: 3.2vw; }
}
@media only screen and (max-width: 500px) {	
	.intro .container { display: none; }
}



/* ================================================================================== */
/* == What is CrossFit? ============================================================= */
/* ================================================================================== */

.intro-video { background: #fff; padding: var(--padding) 0; }
.intro-video .what-is-crossfit { float: left; width: calc(50% - 35px); }
.intro-video .video { float: right; width: calc(50% - 35px); position: relative; padding-bottom: 26.25%; height: 0; }
.intro-video .video iframe { position: absolute; top: 0; left: 0; width: 100% !important; height: 100% !important; }

@media only screen and (max-width: 900px) {
	.intro-video { background-image: linear-gradient( 0deg, #f6f7f9 0%, #ffffff 100%); }
	.intro-video .what-is-crossfit { float: none; width: 100%; }
	.intro-video .video { float: none; width: 100%; padding-bottom: 56.25%; margin-top: var(--padding); }
}

.intro-video a { font-weight: bold; }
.intro-video a:hover { text-decoration: underline; }



/* ================================================================================== */
/* == WOD =========================================================================== */
/* ================================================================================== */

.wod { overflow: hidden; background: #f6f7f9; padding: var(--padding) 0; }
.wod .athletes { float: left; width: calc(50% - 35px); height: 620px; position: relative; z-index: 2; background: url(../img/athletes.png) no-repeat bottom; background-size: contain; }
.wod iframe { max-width: 100% !important; }
.wod .feed { float: right; width: calc(50% - 35px); position: relative; z-index: 2; }
.wod:after { content: ""; position: absolute; bottom: -300px; left: 0; width: 100%; height: 500px; background: var(--color-dark); z-index: 1; transform: skewY(187.5deg); transform-origin: 100%; }
.wod .feed a { display: block; background: #3B5998 url(../img/icon-facebook.svg) no-repeat 15px; background-size: 20px; color: #fff; font-weight: bold; text-shadow: 0 1px 2px rgba(0,0,0,0.3); line-height: 50px; padding: 0 20px 0 50px; border-radius: 0 0 2px 2px; font-size: 0.95em; }
.wod .feed a:after { content: " CrossFit Discipline on Facebook"; }

@media only screen and (min-width: 1200px) {
	.wod .athletes { width: calc(100% - 535px); }
	.wod .feed { width: 500px; }
}
@media only screen and (max-width: 900px) {
	.wod .athletes { float: none; width: 100%; height: auto; padding-bottom: 100%; margin-bottom: var(--padding); }
	.wod .feed { float: none; width: 100%; max-width: 500px; margin: 0 auto; }
	.wod:after { bottom: -300px; height: 1200px; transform: skewY(187.5deg); }
	.wod .feed h2 { color: #fff; }
}
@media only screen and (max-width: 500px) {
	.wod:after { bottom: -30%; }
}
@media only screen and (max-width: 400px) {
	.wod .feed a:after { content: " us on Facebook"; }
	.wod:after { bottom: -40%; }
}
@media only screen and (max-width: 320px) {
	.wod .feed a:after { content: " us on Facebook"; }
	.wod:after { bottom: -47%; }
}


.coaches { background: var(--color-dark); overflow: visible; }
.coaches .container { background: #fff; margin-bottom: -200px; z-index: 9; width: calc(100% - 220px); box-shadow: 0 5px 20px rgba(0,0,0,0.1), 0 3px 10px rgba(0,0,0,0.1); padding: var(--padding); }
.coaches ul { display: flex; justify-content: space-between; }
.coaches li { width: calc(100% / 6 - 10px); text-align: center; }
.coaches li img { display: block; width: 100%; margin-bottom: 0.5em; }
.coaches li h3 { margin: 0; font-style: normal; font-family: "proxima-nova"; }
.coaches li p { margin: 0; }


.instagram-feed { background: var(--color-dark); overflow: hidden;}
.instagram-feed li img { display: block; width: 100%; height: auto; }
.instagram-feed li { float: left; width: calc(100% / 8); }



/* ================================================================================== */
/* == Map  ========================================================================== */
/* ================================================================================== */

.map { background: url(../img/map3.jpg) right center; background-size: cover; position: relative; }
.map .container {  -webkit-transform-style: preserve-3d; -moz-transform-style: preserve-3d; transform-style: preserve-3d; }
.map .directions { display: block; background: var(--color-primary) url(../img/icon-car.svg) no-repeat 16px center; color: #fff; padding: 15px 18px 15px 52px; border-radius: 4px; font-weight: bold;  text-shadow: 0 1px 2px rgba(0,0,0,0.3); text-align: left; }
.map .directions:hover { background: #FFF953 url(../img/icon-car-black.svg) no-repeat 16px center; color: var(--color-dark); text-shadow: none; }
.map .info-box {  background: RGBA(185,52,68, .75); background: RGBA(24,25,27, .85); width: 380px; padding: 50px; }
.map a { color: inherit; }
.map a span { text-decoration: underline; }
.map h2 { color: #fff; margin-top: -0.25em; background: url(../img/skull-logo.png) no-repeat center top; background-size: 140px auto; padding-top: 125px; font-size: 2.5em; text-align: center; }
.map h2 em { color: var(--color-primary); }
.map h3 { color: #fff; margin: 0 0 0.25em 0; font-style: normal; font-size: 0.9em; letter-spacing: 0.07em; text-transform: uppercase; font-family: "proxima-nova"; }
.map p { margin-bottom: 1.15em; }

@media only screen and (min-width: 750px) {
	.map .info-box { position: relative; top: 50%; transform: translateY(-50%); }
	.map .container { height: 750px; }
}
@media only screen and (max-width: 750px) {
	.map { background: url(../img/map-mobile.jpg) center top; background-size: cover; }
	.map .info-box { width: 100%; padding: var(--padding); }
	.map .container { height: auto; padding: var(--padding); padding-top: 400px; }
}
@media only screen and (max-width: 450px) {
	.map h2 { font-size: 2em; padding-top: 110px; background-size: 120px; margin-bottom: 1em; }
}
@media only screen and (max-width: 320px) {
	.map .container { padding-top: 300px; }
	.map h2 { padding-top: 95px; background-size: 95px; margin-top: 0; }
	.map .info-box { text-align: center; }
}



/* ================================================================================== */
/* == Success ======================================================================= */
/* ================================================================================== */

.success { overflow: hidden; padding: var(--padding) 0; background: var(--color-dark); }
.success img { display: block; width: 100%; }
.success .text { float: left; width: calc(50% - 30px); position: relative; z-index: 3; }
.success:after {  content: ""; position: absolute; top: 0px; left: 50%; width: 300px; height: calc(100% + 140px); z-index: 1; content: ""; height: 0; width: 0; border-style: solid; border-color: transparent transparent var(--color-dark) var(--color-dark); border-width: 800px 0 0 180px; }
.success h2 { color: #fff; }
.success h2 em { color: var(--color-primary-alt); }
.success .container:before { content: ""; position: absolute; top: 30%; left: -25%; width: 600px; height: 600px; border: 2px solid #fff; border-radius: 50%; z-index: 5; opacity: 0.05; }

@media only screen and (min-width: 850px) {
	.success img { display: none; }
	.success:before { content: ""; position: absolute; top: 0; right: 0; width: 50%; height: 100%; background: var(--color-dark) url(../img/testimonial2b.jpg) no-repeat center; background-size: cover; }
}
@media only screen and (max-width: 1000px) {
	.success:after { border-left-width: 120px; }
}
@media only screen and (max-width: 850px) {
	.success { padding: 0; }
	.success:after { display: none;}
	.success .container { padding: 0; }
	.success .text { float: none; width: 100%; background: var(--color-dark); padding: var(--padding); }
	.success .text:after {content: ""; position: absolute; top: -70px; right: 0; height: 0; width: 0; border-style: solid; border-color: transparent transparent var(--color-dark) var(--color-dark); border-width: 70px 0 0 900px;  }
	.success .container:before { display: none; }
}



/* ================================================================================== */
/* == Testimonials ================================================================== */
/* ================================================================================== */

.testimonials { background: #f5f5f5; padding: var(--padding) 0; }
.testimonials h2 { margin-bottom: var(--padding); padding-left: calc(var(--padding) / 2); }
.testimonials ul {  }
.testimonials ul li { padding: calc(var(--padding) / 2); }
.testimonials ul li .card { background: #fff; box-shadow: 0px 1px 5px rgba(0,0,0,0.15); padding: 40px; border-radius: 3px; }
.testimonials ul li img { display: block; width: 80px; border-radius: 50%; margin: -75px auto 1em; box-shadow: 0px 1px 4px rgba(0,0,0,0.45); }
.testimonials .rating { background: url(../img/icon-star.svg) repeat-x left; background-size: 18px; text-indent: -9999px; height: 20px; width: 90px; margin: 0 auto 1em; }
.testimonials .name { font-weight: bold; color: var(--darkest-text); display: block; text-align: center; }
.testimonials .subline { display: block; margin: 2em 0 -0.5em 0; text-align: center; color: var(--default-text); font-style: italic; font-size: 0.95em; padding: 0 var(--padding); }
.testimonials .subline:hover { text-decoration: underline; }
.testimonials .container { max-width: calc(1200px + var(--padding)); }

@media only screen and (max-width: 750px) {
	.testimonials .container { padding: 0; }
	.testimonials ul li { padding: 40px 25px 0 25px; }
}
@media only screen and (max-width: 500px) {
	.testimonials ul li { padding: 40px 15px 0 15px; }
	.testimonials ul li .card { padding:  40px 30px 30px 30px; }
	.testimonials h2 { padding: 0 var(--padding); margin-top: 0; }
}
@media only screen and (max-width: 320px) {
	.testimonials ul li { padding: 40px 7px 0 7px; }
	.testimonials ul li .card { padding:  40px 20px 20px 20px; }
}



/* ================================================================================== */
/* == Pricing ======================================================================= */
/* ================================================================================== */

.pricing { overflow: hidden; background: #fff; text-align: center; padding: var(--padding) 0; }
.pricing h2 { margin-bottom: 2rem; }
.pricing ul { display: flex; justify-content: space-between; margin-bottom: 2em; }
.pricing li { width: calc(100% / 5 - 15px); border: 2px solid #E5E5E5; text-align: center; padding: 50px 20px; border-radius: 5px; }
.pricing li h3 { font-size: 1.7em; margin: 0 0 1em 0; font-style: normal; }
.pricing li .price { font-weight: bold; font-size: 3em; color: var(--darkest-text); margin: 0; }
.pricing li p { font-size: .9em; }
.pricing li:first-child { background: var(--color-primary); border: var(--color-primary); color: #fff; }
.pricing li:first-child .price,
.pricing li:first-child h3 { color: #fff; }
.pricing p:last-child { margin-bottom: 0; }
.pricing .subline { font-size: .95em; }

@media only screen and (max-width: 900px) {
	.pricing ul { flex-wrap: wrap; margin-bottom: 0; }
	.pricing li { width: calc(50% - 15px); margin-bottom: 2em; }
	.pricing li:first-child { width: 100%; }
	.pricing li h3 { margin: 0; }
}
@media only screen and (max-width: 500px) {
	.pricing li { padding: 35px 20px; }
}
@media only screen and (max-width: 320px) {
	.pricing ul { display: block; }
	.pricing li { width: 100%; padding: 20px; }
	.pricing li h3 { margin: 0; }
}



/* ================================================================================== */
/* == Schedule ====================================================================== */
/* ================================================================================== */

.schedule { padding: var(--padding) 0; background: var(--color-primary); color: #fff; background-image: linear-gradient( 165deg, var(--color-primary-alt) 0%, var(--color-primary) 100%); background: var(--color-primary) url(../img/schedule-bg.jpg) no-repeat center; background-size: cover; }
.schedule h2 { color: var(--color-dark); }
.schedule ul { display: flex; justify-content: space-between; }
.schedule li { width: calc(100% / 7 - 10px); text-align: center; border: 1px solid rgba(0,0,0,0.1); border-radius: 3px;  overflow: hidden; padding: 8px; background: rgba(20,0,0,0.15); display: flex; flex-direction: column; background: var(--color-dark); }
.schedule .day { background: var(--color-dark); display: block; font-family: "rift"; font-weight: bold; letter-spacing: .025em; color: #fff; font-size: 1.25em; padding: 7px 5px; margin: -8px -8px 1px -8px; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
.schedule .hour { background-image: linear-gradient( 165deg, rgba(255,255,255,0.22) 0%, rgba(255,255,255,0.1) 100%); padding: 10px 0; margin-bottom: 8px;  border-radius: 3px; box-shadow: 0px 1px 4px rgba(0,0,0,0.2); }
.schedule .hour p { margin: 0 auto; text-shadow: 0 1px 1px rgba(0,0,0,0.6); font-size: 0.9em; font-weight: bold; min-width: 110px; }
.schedule .hour p:last-child { font-weight: normal; }
.schedule .hour.none { opacity: 0.45; }
.schedule .hour.none p { visibility: hidden; }
.schedule .hour:last-child { margin-bottom: 0; }
.schedule .headline { overflow: hidden; }
.schedule .headline h2 { float: left; }
.schedule .headline p { float: left; font-size: 1.5em; color: var(--color-dark); opacity: 0.72; margin-top: 3px; font-family: "rift", sans-serif; font-style: italic; font-weight: bold; padding-left: 15px; }

.schedule-mobile { display: none; background: var(--color-primary); color: #fff; background-image: linear-gradient( 165deg, var(--color-primary-alt) 0%, var(--color-primary) 100%); padding: var(--padding) 0; text-align: center; background: var(--color-primary) url(../img/schedule-bg3.jpg) no-repeat top right; background-size: cover; }
.schedule-mobile p:last-child { margin: 0; }
.schedule-mobile .headline h2 { margin: 0; color: #fff; text-shadow: 1px 2px 1px rgba(0,0,0,0.5), 0px 1px 5px rgba(0,0,0,0.25); }
.schedule-mobile .headline p { font-size: 1.5em; color: var(--darkest-text); opacity: 0.72; margin-top: 3px; font-family: "rift", sans-serif; font-style: italic; font-weight: bold; text-shadow: none;}
.schedule-mobile strong { display: block; text-shadow: 1px 1px 1px rgba(0,0,0,0.5), 0px 1px 5px rgba(0,0,0,0.25); font-size: 1.4em; margin: 1.5em 0 .25em 0; text-transform: uppercase;font-family: "rift", sans-serif; font-weight: bold; }
.schedule-mobile p { text-shadow: 1px 1px 1px rgba(0,0,0,0.3), 0px 1px 5px rgba(0,0,0,0.25); font-size: 1.2em;}

@media only screen and (max-width: 1040px) {
	.schedule .hour p { max-width: 90px; min-width: 0; }
}
@media only screen and (max-width: 900px) {
	.schedule { display: none; }
	.schedule-mobile { display: block; }
}
@media only screen and (max-width: 320px) {
	.schedule-mobile .headline p { font-size: 1.3em; }
} 



/* ================================================================================== */
/* == Gallery ======================================================================= */
/* ================================================================================== */

.gallery { background: var(--color-dark); overflow: hidden; padding-top: var(--padding); }
.gallery h2 { color: #fff; }
.gallery li img { display: block; width: 100%; height: auto; }
/*.gallery ul { display: flex; justify-content: space-between; flex-wrap: wrap; }
.gallery li { width: calc(100% / 6 - 30px); border: 2px solid #fff; }*/
.gallery li { float: left; width: calc(100% / 6 - 17px); border: 2px solid #fff; margin: 0 20px 20px 0; }
.gallery li:nth-child(6n) {  margin-right: 0; }

@media only screen and (max-width: 800px) {
	.gallery li { width: calc(100% / 4 - 17px); margin-right: 20px !important; }
	.gallery li:nth-child(4n) { margin-right: 0 !important; }
}
@media only screen and (max-width: 800px) and (min-width: 550px) {
	.gallery li:nth-child(17),
	.gallery li:nth-child(18) { display: none; }
}
@media only screen and (max-width: 550px) {
	.gallery li { width: calc(100% / 3 - 17px); margin-right: 20px !important; }
	.gallery li:nth-child(4n) { margin-right: 20px !important; }
	.gallery li:nth-child(3n) { margin-right: 0 !important; }
}



/* ================================================================================== */
/* == Links ========================================================================= */
/* ================================================================================== */

#links { background: var(--color-dark); padding: var(--padding) 0; }
#links .container { display: flex; justify-content: space-between; }
#links .container:after { display: none; }
#links h3 { font-size: 1.5em; color: #fff; margin-bottom: 0.25em; padding-bottom: 0.15em; border-bottom: 1px solid var(--color-primary); }
#links .column { min-width: 18%; }
#links .logo img { width: 160px; }
#links .logo h2 { color: #fff; background:  url(../img/skull-logo.png) no-repeat center top; background-size: 110px auto; padding-top: 100px; font-size: 1.5em; text-align: center; }
#links .logo h2 em { color: var(--color-primary); }

#links li { float: left; margin-right: 20px; }
#links li a { display: block; text-indent: -9999px; width: 50px; height: 80px; opacity: 0.5;}
#links li a:hover { opacity: 1; }
#links li.facebook a { background: url(../img/facebook.svg) no-repeat center; background-size: 100% auto; }
#links li.twitter a { background: url(../img/twitter.svg) no-repeat center; background-size: 100% auto; }
#links li.instagram a { background: url(../img/instagram.svg) no-repeat center; background-size: 100% auto; }
#links li.journal a { background: url(../img/journal.png) no-repeat center; background-size: 100% auto; width: 110px; }
#links li.rogue a { background: url(../img/rogue.png) no-repeat center; background-size: 100% auto; width: 153px; }
#links li:last-child { margin: 0; }

@media only screen and (max-width: 900px) {
	#links .container { display: block; }
	#links .column { overflow: hidden; margin-top: var(--padding); }
	#links .column:first-child { margin-top: 0; }
}



/* ================================================================================== */
/* == Footer ======================================================================== */
/* ================================================================================== */

#footer { background: #0D0E0F; font-size: 12px; overflow: hidden; padding: 25px 0; }
#footer p { margin: 0; }
#footer p:first-child { float: left; }
#footer p:last-child { float: right; }
#footer a { color: inherit; }

@media only screen and (max-width: 320px) {
	#footer p { float: none !important; text-align: center; line-height: 1.6;}
}



/* ================================================================================== */
/* == Slick Slider ================================================================== */
/* ================================================================================== */

/* Slider */
.slick-slider { position: relative; display: block; 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; }
.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; outline: none; }
.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-loading .slick-list { background: url(../img/loader.svg) no-repeat center center; background-size: 70px; }

/*.slick-slide { opacity: 0; transition: all 0.5s;}
.slick-slide.slick-active { opacity: 1; }*/

/* Dots */
.slick-dotted.slick-slider { margin-bottom: 30px; }
.slick-dots { position: absolute; bottom: -25px; display: block; width: 100%; padding: 0; margin: 0; list-style: none; text-align: center; }
.slick-dots li { position: relative; display: inline-block; width: 20px; height: 20px; margin: 0 5px; padding: 0; cursor: pointer; }
.slick-dots li button { font-size: 0; line-height: 0; display: block; width: 20px; height: 20px; padding: 5px; cursor: pointer; color: transparent; border: 0; outline: none; background: blue; }
.slick-dots li button:hover,
.slick-dots li button:focus { outline: none; }
.slick-dots li button:hover:before,
.slick-dots li button:focus:before { opacity: 1; }
.slick-dots li button:before { font-family: 'slick'; font-size: 6px; line-height: 20px; position: absolute; top: 0; left: 0; width: 20px; height: 20px; content: '•'; text-align: center; opacity: .25; color: black; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
.slick-dots li.slick-active button:before { opacity: .75; color: black; }

/* Arrows */
.slick-arrow {width: 60px; height: 90px; margin: -45px 0 0; display: block; background: url(../img/icon-slider-arrows-black.svg) no-repeat center; background-size: auto 60px; border: none; position: absolute; top: 50%; cursor: pointer; text-indent: -9999px; opacity: 1; -webkit-transition: all .3s ease; z-index: 9;}
.slick-slider .slick-next {background-position: calc(100% - 10px) center; right: -60px; }
.slick-slider .slick-prev {background-position: 10px center; left: -60px;}

@media only screen and (max-width: 1200px) {
	.slick-slider .slick-next { right: -48px; }
	.slick-slider .slick-prev { left: -48px;}
}
@media only screen and (max-width: 750px) {
	.touchevents .slick-slider .slick-next,
	.touchevents .slick-slider .slick-prev { display: none !important; }
	.no-touchevents .slick-slider .slick-next,
	.no-touchevents .slick-slider .slick-prev { opacity: 0; }
	.no-touchevents .slick-slider .slick-next { right: -60; }
	.no-touchevents .slick-slider .slick-prev { left: -60; }
	.no-touchevents .slick-slider:hover .slick-next,
	.no-touchevents .slick-slider:hover .slick-prev { opacity: 1; }
	.no-touchevents .slick-slider:hover .slick-next { right: 0; }
	.no-touchevents .slick-slider:hover .slick-prev { left: 0; }
}



/* ================================================================================== */
/* == WOD Page ====================================================================== */
/* ================================================================================== */

.wod-page { padding: var(--padding) 0; }
.wod-page .feed { float: right; width: 50%; }
.wod-page .feed iframe { max-width: 100% !important; }
.wod-page .terms { float: left; width: calc(50% - var(--padding)); }
.wod-page .terms strong { color: var(--darkest-text); }
.wod-page .terms strong:after { content: " - "; }
.wod-page .feed a { display: block; background: #3B5998 url(../img/icon-facebook.svg) no-repeat 15px; background-size: 20px; color: #fff; font-weight: bold; text-shadow: 0 1px 2px rgba(0,0,0,0.3); line-height: 50px; padding: 0 20px 0 50px; border-radius: 0 0 2px 2px; font-size: 0.95em; }

@media only screen and (max-width: 750px) {
	.wod-page .feed { float: none; width: 100%; }
	.wod-page .terms { float: none; width: 100%; margin-top: var(--padding); }
}



/* ================================================================================== */
/* == Join Page ===================================================================== */
/* ================================================================================== */

.join-page { padding-top: var(--padding); }



/* ================================================================================== */
/* == Events Page =================================================================== */
/* ================================================================================== */

.events-page { padding-top: var(--padding); padding-bottom: var(--padding); }
.events-page img { display: block; max-width: 100%; margin-top: 2rem;  }

.blog-list { margin-top: 55px; }
.blog-list li { overflow: hidden; margin-bottom: 55px; }
.blog-list li a { display: block; overflow: hidden; color: var(--default-text); }
.blog-list li .thumbnail { float: left; width: 300px; margin: 0; border: 1px solid #e5e5e5; }
.blog-list li .text { float: right; width: calc(100% - 300px); padding-left: 30px; }
.blog-list li h3 { font-size: 2em; margin-bottom: 0; }



/* ================================================================================== */
/* == FREE Pass Page ================================================================ */
/* ================================================================================== */

.free-pass-page { padding-top: var(--padding); padding-bottom: var(--padding); }
.free-pass-page form { max-width: 400px; background: #f5f5f5; border: 2px solid #e5e5e5; padding: 40px; border-radius: 5px; }
.free-pass-page form ul li { margin-bottom: 1rem; }
.free-pass-page form label { display: block; font-weight: bold; color: var(--darkest-text); line-height: 40px; }
.free-pass-page form input { height: 40px; width: 100%; border-radius: 3px; border: 2px solid #e5e5e5; padding: 0 10px; }
.free-pass-page form input[type='checkbox'] { float: left; margin-right: 10px; padding: 0; width: auto; }

.free-pass-page form button { background: var(--color-primary);
    line-height: 40px;
	width: 100%;
    font-weight: bold;
    color: #fff;
    border-radius: 4px;
    text-shadow: 0 1px 2px rgba(0,0,0,0.3);
    border: none;
    cursor: pointer; }



/* ================================================================================== */
/* == Print Pass Page =============================================================== */
/* ================================================================================== */

.print-pass-page { padding-top: var(--padding); padding-bottom: var(--padding); }
.print-pass-page .faux-pass { border: 2px solid #e5e5e5; padding: 50px; }
.print-pass-page .faux-pass .badge { float: right; background: #000; height: 100px; width: 100px; border-radius: 50%; text-align: center; line-height: 100px; color: #fff; }