/* 
Theme Name: Brett Heidebrecht
Description: Wordpress theme for Brett Heidebrecht, 2020
Author: Dustin Davis
Author URI: http://www.imdustindavis.com
Version: 1


*************



/* LINKS & TYPE
-------------------------------------------------------------------------------
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
-------------------------------------------------------------------------------
*/

html {
	font-size: 16px;
}

body {
	font-family: starling, serif;
	font-weight: 300;
}

a,
a:link,
a:active,
a:visited {
	color: rgb(0,0,0);
	text-decoration: none;
}

 a:hover, 
 a:focus {
	color: rgb(0,0,0);
	text-decoration: none;
}

#main-menu .menu li a:hover,
#main-menu .menu li a:focus {
	color: rgba(0,0,0,0,.25);
	text-decoration: none;	
}

.arrow-button {
	color: rgb(0,0,0);
}

/* HALOGEN */

#main-menu .menu li a,
#mobile-menu .menu li a,
.arrow-button,
span.fs-location,
#footer p,
#footer p a,
.ar-slider-text span,
.wpcf7 label,
[type=button], [type=submit],
.load-more {
	font-family: halogen,sans-serif;
	font-weight: 700;
	font-style: normal;
	letter-spacing: 1.5px;
	text-transform: uppercase;
}

#main-menu .menu li a,
span.fs-location,
.wpcf7 label,
[type=button], [type=submit],
.load-more {	
	font-size: .55rem;
}

#mobile-menu .menu li a {
	font-size: 1.13rem;
	letter-spacing: 5px;
}

#footer p,
#footer p a {
	font-size: .75rem;
}

.arrow-button,
.ar-slider-text span {
	font-size: .6rem;
}

h3 {
	font-family: halogen,sans-serif;
	font-weight: 700;
	font-style: normal;
	font-size: .6rem;
	letter-spacing: 1.5px;
	text-transform: uppercase;	
}




/* STARLING ITAL*/

.landing-slider-image-text .slider span {
	font-size: .75rem;
	font-style: italic;
	line-height: 2.8;
}

.ar-slider-text {
	font-style: italic;
	font-size: .875rem;
	line-height: 38px;
}

.fs-content .fs-excerpt {
	font-size: 1.1rem;
	line-height: 1.8;
}

h1, h2, h3, h4 {
	margin: 0px;
}

h1 {
	font-family: starling, serif;
	font-weight: 900;
}

h2 {
	font-family: starling, serif;
	font-weight: 900;
	font-size: 2rem;
	letter-spacing: .5px;
}

h4 {
	font-family: starling, serif;
	font-weight: 300;
	font-style: italic;
	font-size: 1.1rem;
	line-height: 2.1rem;

}

/* COLORS, FONT SIZES, weights */


.h-900,
.wpcf7 label,
[type=submit],
.ar-slider-text span {
	font-family: halogen,sans-serif;
	font-weight: 900;
	font-style: normal;
}

.wt-title h2 {
	color: rgb(255,255,255);
	line-height: 30px;
}


h1.arrow-go {
	padding-right: 50px;
	font-size: 2rem;
}

h1.arrow-go a {
	position: relative;
	display: flex;
	justify-content: flex-end;
	flex-wrap: nowrap;
	width: 100%;
	overflow: hidden;
	vertical-align: middle;
	text-decoration: none;
	cursor: pointer;
}

h1.arrow-go.for-mobile a {
	display: block;
}

h1.arrow-go.for-mobile span {
	display: block;
}

h1.large-h1 {
	font-size: 1.9rem !important;
	line-height: 2.8rem;
}

h2.sm-h2 {
	font-size: 1rem;
	font-weight: normal;
}

h3.sm-h3 {
	font-size: .5rem;
}

h3.md-h3 {
	font-size: .6rem;
}

h3.lg-h3 {
	font-size: .8rem;
}

.landing-about-section p {
	font-size: 1.1rem;
}

.wt-text {
	color: rgb(255,255,255);
}

.fs-slider .slider-item {
	color: rgb(255,255,255);
}

.h1 small, .h2 small, .h3 small, .h4 small, .h5 small, .h6 small, h1 small, h2 small, h3 small, h4 small, h5 small, h6 small {
    color: inherit;
}

#footer small {
	color: rgb(114,114,114);
}


/** TABS */

.tabs {
	background-color: transparent;
	border: none;
	display: flex;
	justify-content: space-around;
	margin: 0 auto 83px auto;
	position: relative;
	padding: 0px 30px;
	max-width: 1200px;
}


.tabs::after, .tabs::before {
    content: '';
    display: none;
}

.tabs-title {
    float: none;
    position: relative;
    text-align: center;
}


.tabs-title * {
	outline: none;
}

.tabs-title:active,
.tabs-title a:active,
.tabs-title:focus,
.tabs-title a:focus {
	background: transparent;
}

.tabs-content {
	background-color: transparent;
	border: none;
}

.tabs-title>a,
.tabs-title>a:focus,
.tabs-title>a[aria-selected=true] {
    color: #0a0a0a !important;
    background-color: transparent !important;
}



.tabs-title>a {
    display: block;
    padding: 0;
    font-size: inherit;
    line-height: 1;
    color: #1779ba;
}

h2.tab-title {
	position: relative;
	margin-bottom: 35px;
}

h2.tab-title:after,
.tabs-title.is-active:after {
	content: " ";
	background: rgb(232, 229, 224);
    display:block;
    position: absolute;
    bottom: 6px;
    width: 123px;
    height: 14px;
    z-index: -1;
}

.tabs-title.tab-princ.is-active:after {
    left:72px
}

.tabs-title.tab-press.is-active:after {
    right:15px
}

.tabs-title.tab-rev.is-active:after {
    left:54px
}

/* IMAGES, GRAPHICS
-------------------------------------------------------------------------------
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
-------------------------------------------------------------------------------
*/


h1.arrow-go a .go-arrow-img {
	height: 17px;
	width: auto;
}

h1.arrow-go.for-mobile {
	margin-top: 200px;
}

svg.arrow g line,
svg.arrow g polyline{
  	fill: none;
	stroke: rgb(0,0,0);
	stroke-miterlimit: 10;

}

span.large-line {
	display: block;
	height: 8px;
	position: absolute;
	z-index: -1;
}

.landing-about-section span.large-line {
	background-color: rgb(255,255,255);
	width: 68%;
	top: 175px;
	left: 0px;
}


.work-together span.large-line {
	background-color: rgb(114, 114,114);
	width: 33%;
	height: 14px;
	top: 100px;
	left: 0px;
}

.story-credits span.large-line {
	background-color: rgb(232, 229, 224);
	width: 40%;
	top: 26px;
}

.landing-about-section span.large-line g line {
	fill: none;
	stroke: rgb(255,255,255);
	stroke-miterlimit: 10;
	stroke-width: 15px;
}

.work-together span.large-line g line {
	fill: none;
	stroke: rgb(114,114,114);
	stroke-miterlimit: 10;
	stroke-width: 15px;
}

.text-white-block svg.arrow {
	position: absolute;
	right: 0px;
	top: 0px;
	height: 10px;
	width: auto;
}


.grid-x.pub-logos {
	margin: auto;
	max-width: 785px;
}

.pub-logo-cell {
	margin-top: 75px;
}

body.home .pub-logo-cell {
	margin-top: 40px;
}

.pub-logo-cell img {
	max-width: 160px;
}

body.home .pub-logo-cell img {
	max-width: 120px;
}


h1.section-title {
	width: auto;
}

h2.section-title {
	position: relative;
}

h2.section-title:after {
	content: " ";
	background: rgb(232, 229, 224);
    display:block;
    position: absolute;
    bottom: 5px;
    left: 20px;
    width: 40%;
    height: 14px;
    z-index: -1;
}

/* MISC
-------------------------------------------------------------------------------
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
-------------------------------------------------------------------------------
*/

@keyframes fade-in {
	from {
		opacity:0;
	}
	
	to {
		opacity:1;
	}
}

body {
    -webkit-animation: fade-in 1s ease both .5s;
    -moz-animation: fade-in 1s ease both .5s;
    -o-animation: fade-in 1s ease both .5s;
    -ms-transition: fade-in 1s ease both .5s;
    animation: fade-in 1s ease both .5s;
}

#ld {
	position: fixed;
	left: 0px;
	right: 0px;
	top: 0px;
	bottom: 0px;
	background-color: white;
	height: 100%;
	width: 100%;
	z-index: 100000;
}

.arrow-button {
	background-image: url("_/images/go-arrow.png");
	background-position: right center;
	background-repeat: no-repeat;
	background-size: 40px;
	display: block;
	position: relative;
	width: 100%;
}

.arrow-button a {
	display: block;
	width: 100%;
}


.arrow-button span {
	display: inline-block;
	position: relative;
	padding: 0px 10px;
	z-index: 1;
}

.arrow-button span:after {
	content: " ";
	background: rgb(255,255,255);
    display:block;
    position: absolute;
    top: 6px;
    left: 0px;
    width: 80%;
    height: 9px;
    z-index: -1;
}

hr {
    clear: both;
    max-width: 75rem;
    height: 1px;
    margin: 1.25rem auto;
    border-top: 0;
    border-right: 0;
    border-bottom: 0;
    border-left: 0;
}

hr.sm {
	background-color: rgb(0,0,0);
	width: 12px;
	margin: auto;
}

h1.arrow-go {
	padding-right: 10%;
}

h1.arrow-go a span:first-child {
	padding-right: 50px;
}

/* HEADER / FOOTER
-------------------------------------------------------------------------------
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
-------------------------------------------------------------------------------
*/

.sticky.is-stuck {
    z-index: 99991 !important;
}

img.header-estd {
	max-width: 32px;
	height: auto;
	margin-bottom: 0px;
	display: none;
}

body.home img.header-estd {
	display: block;
	margin: 0px auto 18px auto;
}

header#header {
	display: block;
	height: auto;
	padding-top: 0px;
	margin-top: 33px;
}

header#header nav .sticky {
	background-color: rgb(255,255,255);
}

nav .menu-main-menu-container {
	max-width: 920px;
	margin: auto;
}

#main-menu img {
	max-width: 140px;
	width: 100%;
	height: auto;
}

body.home #main-menu img {
	max-width: 312px;
}

#main-menu .sticky.is-stuck {
	padding-top: 20px;
	padding-bottom: 20px;
	transition: padding 0.5s ease;
}

#main-menu .sticky.is-anchored {
	padding-top: 0px;
	padding-bottom: 20px;
}

body.home #main-menu a.menu-image-title-hide.menu-image-not-hovered {
	margin: 0px calc(100px - 1rem);
}

#main-menu .sticky.is-stuck a.menu-image-title-hide.menu-image-not-hovered {
	margin: 0px 0;
}

#main-menu .sticky.is-stuck img{
	max-width: 140px;
}

#main-menu .menu {
	flex-wrap: nowrap;
	align-items: center;
	justify-content: center;
}

#main-menu .menu li {
	flex-grow: 1;
	text-align: center;
}

.position-left {
    width: 100%;
    -webkit-transform: translateX(-100%);
    -ms-transform: translateX(-100%);
    transform: translateX(-100%);
}

.position-left.is-transition-push {
    -webkit-box-shadow: none;
    box-shadow: none;
}

.off-canvas-content.is-open-left.has-transition-push {
    -webkit-transform: translateX(100%);
    -ms-transform: translateX(100%);
    transform: translateX(100%);
}

.off-canvas-button {
	/*background-color: rgb(255,255,255);*/
	position: fixed;
	left: 20px;
	top: 37px;
	width: 100%;
	max-width: 40px;
	padding: 10px;
	height: auto;
	z-index: 9999;
}

.close-button, .close-button.medium {
	position: fixed;
	right: 40px;
	top: 40px;
    outline: none;
    height: 28px;
    width: 28px;
    font-size: 0px;

}

.close-button span {
	font-size: 2.5rem;
    height: 8px;
    width: 8px;
    outline: none;
    font-size: 0px;
}

.off-canvas {
    background: rgb(228,223,219);
}


img.mobile-logo {
	max-width: 175px;
	height: auto;
}

.close-button img {
	max-width: 8px;
	height: auto;
}


#mobile-menu {
	padding: 0px;
	margin-top: 80px;
	text-align: center;
}


#mobile-menu img.mobile-logo {
	display: block;
	max-width: 175px;
	margin: auto;
    width: 100%;
    height: auto;
}

#mobile-menu img.header-estd {
	width: 25px;
	height: auto;
	display: block;
	margin: 0px auto 18px auto;
}

#mobile-menu hr {
	background-color: rgb(255,255,255);
	height: 2.5px;
	margin: 30px auto 15px auto;
	width: 100px;
}

.menu-mobile-menu-container {
	margin: auto;
	max-width: 270px;
	width: 100%;
}

#mobile-menu a {
	display: block;
}

#mobile-menu .menu,
#mobile-menu .menu li {
	display: block;
}

#mobile-menu .menu li {
	border-bottom: 1px rgb(0,0,0) solid;
}

#mobile-menu .menu li:last-child {
	border: none;
}

#mobile-menu .menu .button, 
#mobile-menu .menu a {
	padding: 35px 0px;
}

img.footer-estd {
	max-width: 80px;
	height: auto;
	margin-bottom: 40px;
}

#footer {
	background-color: rgb(217, 214,206);
	padding: 60px 0px 20px 0px;
}

body.home #footer {
	background-color: transparent;
}

body.error404 footer#footer {
	margin-top: 100px;
}

#footer a {
	margin: 0px 10px;
}

/* GENERAL LAYOUT
-------------------------------------------------------------------------------
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
-------------------------------------------------------------------------------
*/

body {
	-webkit-overflow-scrolling: touch;
}

.off-canvas-wrapper, 
.off-canvas-wrap .inner-content {
	height: 100%;
    width: 100%;
}

#wrapper {
	position: relative;
	margin: auto;
}

body.page-template-default #wrapper {
	margin: 50px 0px 100px 0px;
}



section.error {
	background-color: rgb(206, 200,187);
	margin: 100px 0px;
	padding: 100px 0px;
}




/* MEDIA QUERIES
-------------------------------------------------------------------------------
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
-------------------------------------------------------------------------------
*/

@media only screen and (max-width:  768px) {
	
	.pub-logo-cell img {
		max-width: 130px;
	}

}



@media only screen and (min-width:  640px) {
	
	.for-mobile {
		display: none;
	}
}



@media only screen and (max-width:  640px) {
		
	.for-desktop {
		display: none;
	}
	
	header#header {
	    height: auto;
	    padding-top: 50px;
	    margin-top: 0px;
	}
	
	body.home header#header {
	    height: auto;
	    padding-top: 0px;
	    margin-top: 25px;
	    position: absolute;
	    z-index: 10;
	    width: 100%;
	}
	
	.tabs-title.is-active:after {
	    right: 10px;
	    width: 50%;
	}
	
	.story-credits span.large-line {
	    top: 15px;
	    left: -10px;
	}
	
	.load-more {
		font-size: .5rem;
	}
	
	#footer p,
	#footer p a {
		font-size: .5rem;
	}
	
	.pub-logo-cell {
		margin-top: 35px;
		padding: 0px 0px;
	}
	
	.pub-logo-cell img {
		max-width: 70px;
	}
		
	.landing-about-section span.large-line {
	    width: 95%;
	    top: 87px;
	}
	
	.landing-about-section p {
	    font-size: .9rem;
	}

}

@media only screen and (max-width:  340px) {
	
	#footer p span {
		display: none;
	}
	
}

@media only screen and (max-width:  415px) {
	
	#footer a {
		margin: 0px 3px;
	}
	
	.arrow-button {
		font-size: .5rem;
	}
	
	img.footer-estd {
	    max-width: 40px;
	    height: auto;
	    margin-bottom: 20px;
	}
	
	h2 {
		font-size: 1.55rem;
	}
	
	h3 {
	    font-size: .5rem;
	    letter-spacing: 1.5px;
	}
	
	.story-credits h3.lg-h3 {
	    font-size: .6rem;
	}
	.story-credits h3.md-h3 {
    	font-size: .5rem;
	}
	
	h4 {
		font-size: .9rem;
		line-height: 1.4rem;
	}
	
	.tabs-title.is-active:after {
	    right: 5px;
	    width: 50%;
	    bottom: 10px;
	}
	
	.tabs-title h2 {
    	font-size: 1.5rem;
	}
}

@supports (-webkit-overflow-scrolling: touch) {
 	.sticky.is-stuck {
	 	position: relative;
 	}
}