/*HEY, YOU! WHATCHA LOOKING FOR IN HERE, YOU LITTLE DE-BUGGER?!*/

/**** THE BASICS ****/

@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Anton&display=swap');
@import url('https://fonts.googleapis.com/css?family=Open+Sans:100,200,300,400,500,600,700,800');
html, body {
	background-color: #fcfcfc;
	color: #131313;
	font-family: 'Open Sans', sans-serif !important;
	font-size: 20px !important;
}
h1 {
	font-family: 'Anton','Open Sans', sans-serif !important;
	/*font-weight: 200!important;*/
	text-transform: uppercase;
	font-size: 2.75em !important;
	color: #fcfcfc !important;
	animation: title-glitch 10s infinite;
}



.h1alt { /*styled like an H3 but it's an H1 because SEO / Accessibility, etc */
	font-family: 'Anton','Open Sans', sans-serif !important;
	font-size: 2.15em !important;
	text-transform: uppercase;
	padding-top: 10px;
	padding-bottom: 10px;
	color: rgba(19,19,19,1.00) !important;
}
h2 {
	font-family: 'Anton','Open Sans', sans-serif !important;
	font-size: 1.15em !important;
	text-transform: uppercase;
	padding-top: 10px;
	padding-bottom: 10px;
}
h3 {
	font-family: 'Anton','Open Sans', sans-serif !important;
	font-size: 2.15em !important;
	text-transform: uppercase;
	padding-top: 10px;
	padding-bottom: 10px;
}
.j-poster h3 { /* Instagram feed title style */
	font-size: 1em !important;
}


.number1 {
	background-image: url("images/structure/number1.png");
	background-repeat: no-repeat;
	background-position: left bottom;
	display:block;
	padding-top: 1.95em;
	padding-left: 8.33333333%;
}
.number1alt {
	background-image: url("images/structure/number1.png");
	background-repeat: no-repeat;
	background-position: 22% bottom;
	display:block;
	padding-top: 1.95em;
	text-align: center;
}
.number2 {
	background-image: url("images/structure/number2.png");
	background-repeat: no-repeat;
	background-position: left bottom;
	display:block;
	padding-top: 1.95em;
	padding-left: 8.33333333%;
}
.number2dark {
	background-image: url("images/structure/number2-dark.png");
	background-repeat: no-repeat;
	background-position: 20% bottom;
	display:block;
	padding-top: 1.95em;
	text-align: center;
}
.number2darkalt{
	background-image: url("images/structure/number2-dark.png");
	background-repeat: no-repeat;
	background-position: left bottom;
	display:block;
	padding-top: 1.95em;
	padding-left: 8.33333333%;
	text-align: left;
}
.number3 {
	background-image: url("images/structure/number3.png");
	background-repeat: no-repeat;
	background-position: 20% bottom;
	display:block;
	padding-top: 1.95em;
	text-align: center;
}
.number3alt{
	background-image: url("images/structure/number3.png");
	background-repeat: no-repeat;
	background-position: left bottom;
	display:block;
	padding-top: 1.95em;
	padding-left: 8.33333333%;
	text-align: left;
}
.number3light {
	background-image: url("images/structure/number3-light.png");
	background-repeat: no-repeat;
	background-position: 20% bottom;
	display:block;
	padding-top: 1.95em;
	text-align: center;
}
.number3lightalt{
	background-image: url("images/structure/number3-light.png");
	background-repeat: no-repeat;
	background-position: left bottom;
	display:block;
	padding-top: 1.95em;
	padding-left: 8.33333333%;
	text-align: left;
}
.number4 {
	background-image: url("images/structure/number4.png");
	background-repeat: no-repeat;
	background-position: left bottom;
	display:block;
	padding-top: 1.95em;
	padding-left: 8.33333333%;
}
.number4dark {
	background-image: url("images/structure/number4-dark.png");
	background-repeat: no-repeat;
	background-position: left bottom;
	display:block;
	padding-top: 1.95em;
	padding-left: 8.33333333%;
}
@media only screen and (max-width: 600px) {
	h3 {
		font-size: 1.35em !important;
	}
	.number1 {
		padding-top: 2.1em;
	}
	.number2, .number2dark, .number2darkalt {
		padding-top: 2.1em;
	}
	.number3 {
		background-position: left bottom;
		padding-left: 8.33333333%;
		padding-top: 2.1em;
	}
	.h1alt {
	font-size: 1.35em !important;		
	}
}
h3 .bottom-headline {
	font-size: 1.3em !important;
	display:block;
}
h4, h5, h6 {
	font-family: 'Open Sans', sans-serif !important;
	font-weight: 600;
}
.myname {
	font-family: 'Anton','Open Sans', sans-serif !important;
	margin-left:20px;
	border-left: 1px solid #f9f9f9;
	padding-left: 20px;
	padding-right: 20px;
	animation: title-glitch 15s infinite;
}
.light-text {
	color: #fcfcfc !important;
}
@media only screen and (max-width: 992px) {
	.hideonmobile {
		display: none;
	}
}
@media only screen and (min-width: 993px) {
	.hideondesktop {
		display: none;
	}
}


::-webkit-scrollbar {
  width: 10px;
}

/* Track */
::-webkit-scrollbar-track {
  background: #2a2a2a; 
}
 
/* Handle */
::-webkit-scrollbar-thumb {
  background: #555; 
}

/* Handle on hover */
::-webkit-scrollbar-thumb:hover {
background: rgb(236,0,140);
background: linear-gradient(69deg, rgba(236,0,140,1) 8%, rgba(0,212,255,1) 91%);
}



/* Global custom text selection */
::selection {
  background-color: #00d2ff; /* cyan */
  color: #000;               /* text color while selected */
}

/* Firefox needs its own prefix */
::-moz-selection {
  background-color: #00d2ff;
  color: #000;
}


/* Makes YouTube videos responsive */
.youtube-video {
  aspect-ratio: 16 / 9;
  width: 100%;
}


/**** FOOTER ****/

.footer-text {
	font-size: 16px !important;
	font-weight: 550;
}

.footer-name {
	flex: 0 0 auto;
    width: 41.66666667%;
}

@media only screen and (min-width: 99px) {
	.footer-logo {
	display: none;
	}
}

@media only screen and (max-width: 993px) {
	.hideonmobile-footer {
		
		display: none;
	
	}
	.footer-name {
		
		width: 100%;
		text-align: center;
	
	}
	.footer-logo {
		
	display: inline;

	}
}



/*****  RESPONSIVE VIDEO *****/
.videoWrapper {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 */
  height: 0;
}
.videoWrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}




/***** THE SNAZZY CONTACT MODAL *****/
.modal-content {
	background-color: #fcfcfc !important;
}
.modal-flex-container {
  display: flex;
  flex-direction: row;
}

.modal-flex-item-left {
  padding: 10px;
  flex: 50%;
  text-align: left !important;
  margin-top: 45px;
}

.modal-flex-item-right {

  padding: 10px;
  flex: 50%;
}
.contact-icon{
	margin-right: 10px;
}
/* Responsive layout - makes a one column-layout instead of two-column layout */
@media (max-width: 992px) {
	.modal-flex-container {
	flex-direction: column;
  }
	
	.modal-flex-item-left {
	  margin-top: 0px;
	}
	.modal-flex-item-right {
	order: -1;
	}
}
@media (max-width: 374px) {
	.modal-contact-text {
		text-align: center;
	}
	.contact-icon {
		display: none;
	}
}






/***** THE SNAZZY PRELOADER *****/
#loader-wrapper {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 2000;
}
#loader {
	display: block;
	position: relative;
	left: 50%;
	top: 50%;
	width: 150px;
	height: 150px;
	margin: -75px 0 0 -75px;
	border-radius: 50%;
	border: 3px solid transparent;
	border-top-color: magenta;
	-webkit-animation: spin 2s linear infinite;
	/* Chrome, Opera 15+, Safari 5+ */
	animation: spin 2s linear infinite;
	/* Chrome, Firefox 16+, IE 10+, Opera */
	z-index: 2001;
}
#loader:before {
	content: "";
	position: absolute;
	top: 5px;
	left: 5px;
	right: 5px;
	bottom: 5px;
	border-radius: 50%;
	border: 3px solid transparent;
	border-top-color: cyan;
	-webkit-animation: spin 3s linear infinite;
	/* Chrome, Opera 15+, Safari 5+ */
	animation: spin 3s linear infinite;
	/* Chrome, Firefox 16+, IE 10+, Opera */
}
#loader:after {
	content: "";
	position: absolute;
	top: 15px;
	left: 15px;
	right: 15px;
	bottom: 15px;
	border-radius: 50%;
	border: 3px solid transparent;
	border-top-color: #7657bd;
	-webkit-animation: spin 1.5s linear infinite;
	/* Chrome, Opera 15+, Safari 5+ */
	animation: spin 1.5s linear infinite;
	/* Chrome, Firefox 16+, IE 10+, Opera */
}
@-webkit-keyframes spin {
	0% {
		-webkit-transform: rotate(0deg);
		/* Chrome, Opera 15+, Safari 3.1+ */
		-ms-transform: rotate(0deg);
		/* IE 9 */
		transform: rotate(0deg);
		/* Firefox 16+, IE 10+, Opera */
	}
	100% {
		-webkit-transform: rotate(360deg);
		/* Chrome, Opera 15+, Safari 3.1+ */
		-ms-transform: rotate(360deg);
		/* IE 9 */
		transform: rotate(360deg);
		/* Firefox 16+, IE 10+, Opera */
	}
}
@keyframes spin {
	0% {
		-webkit-transform: rotate(0deg);
		/* Chrome, Opera 15+, Safari 3.1+ */
		-ms-transform: rotate(0deg);
		/* IE 9 */
		transform: rotate(0deg);
		/* Firefox 16+, IE 10+, Opera */
	}
	100% {
		-webkit-transform: rotate(360deg);
		/* Chrome, Opera 15+, Safari 3.1+ */
		-ms-transform: rotate(360deg);
		/* IE 9 */
		transform: rotate(360deg);
		/* Firefox 16+, IE 10+, Opera */
	}
}
#loader-wrapper .loader-section {
	position: fixed;
	top: 0;
	width: 51%;
	height: 100%;
	background: #222222;
	z-index: 1000;
	-webkit-transform: translateX(0);
	/* Chrome, Opera 15+, Safari 3.1+ */
	-ms-transform: translateX(0);
	/* IE 9 */
	transform: translateX(0);
	/* Firefox 16+, IE 10+, Opera */
}
#loader-wrapper .loader-section.section-left {
	left: 0;
}
#loader-wrapper .loader-section.section-right {
	right: 0;
}
/* Loaded */
.loaded #loader-wrapper .loader-section.section-left {
	-webkit-transform: translateX(-100%);
	/* Chrome, Opera 15+, Safari 3.1+ */
	-ms-transform: translateX(-100%);
	/* IE 9 */
	transform: translateX(-100%);
	/* Firefox 16+, IE 10+, Opera */
	-webkit-transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);
	transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);
}
.loaded #loader-wrapper .loader-section.section-right {
	-webkit-transform: translateX(100%);
	/* Chrome, Opera 15+, Safari 3.1+ */
	-ms-transform: translateX(100%);
	/* IE 9 */
	transform: translateX(100%);
	/* Firefox 16+, IE 10+, Opera */
	-webkit-transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);
	transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);
}
.loaded #loader {
	opacity: 0;
	-webkit-transition: all 0.3s ease-out;
	transition: all 0.3s ease-out;
}
.loaded #loader-wrapper {
	visibility: hidden;
	-webkit-transform: translateY(-100%);
	/* Chrome, Opera 15+, Safari 3.1+ */
	-ms-transform: translateY(-100%);
	/* IE 9 */
	transform: translateY(-100%);
	/* Firefox 16+, IE 10+, Opera */
	-webkit-transition: all 0.3s 1s ease-out;
	transition: all 0.3s 1s ease-out;
}
/* JavaScript Turned Off */
.no-js #loader-wrapper {
	display: none;
}



/***** THE SNAZZY GLOW EFFECTS *****/
.glow-pink {
	-webkit-animation: glow 1s ease-in-out infinite alternate;
	-moz-animation: glow 1s ease-in-out infinite alternate;
	animation: glow 1s ease-in-out infinite alternate;
}
@-webkit-keyframes glow {
	from {
		text-shadow: 0 0 5px #fff, 0 0 10px #ffa6db, 0 0 15px #f9acd2, 0 0 20px #f9acd2, 0 0 25px #f9acd2, 0 0 30px #f9acd2, 0 0 70px #f9acd2;
	}
	to {
		text-shadow: 0 0 15px #ffa6db, 0 0 20px #ffa6db, 0 0 30px #f9acd2, 0 0 40px #f9acd2, 0 0 50px #f9acd2, 0 0 60px #f9acd2, 0 0 80px #fff;
	}
}
@keyframes rotate {
	to {
		--angle: 360deg;
	}
}
@property --angle {
	syntax: '<angle>';
	initial-value: 0deg;
	inherits: false;
}


.glow-blue {
	-webkit-animation: glowblue 1s ease-in-out infinite alternate;
	-moz-animation: glowblue 1s ease-in-out infinite alternate;
	animation: glowblue 1s ease-in-out infinite alternate;
}
@-webkit-keyframes glowblue {
	from {
		text-shadow: 0 0 5px #fff, 0 0 10px #7fd6f7, 0 0 15px #005778, 0 0 20px #005778, 0 0 25px #005778, 0 0 30px #005778, 0 0 70px #005778;
	}
	to {
		text-shadow: 0 0 15px #7fd6f7, 0 0 20px #005778, 0 0 30px #005778, 0 0 40px #005778, 0 0 50px #005778, 0 0 60px #005778, 0 0 80px #fff;
	}
}
@keyframes rotate {
	to {
		--angle: 360deg;
	}
}
@property --angle {
	syntax: '<angle>';
	initial-value: 0deg;
	inherits: false;
}


/***** THE SNAZZY GLITCH EFFECTS *****/
@keyframes title-glitch {
  0%, 84%, 100% {
    text-shadow: 0 0 40px rgba(0, 190, 230, 0.05),
                 0 0 90px rgba(0, 155, 210, 0.05);
    transform: none;
  }
  85% {
    text-shadow: -4px 0 rgba(255, 20, 80, 0.65),
                  4px 0 rgba(0, 255, 210, 0.65),
                  0 0 30px rgba(0, 200, 235, 0.5);
    transform: translateX(-2px) skewX(-1.5deg);
  }
  86% {
    text-shadow: 4px 0 rgba(255, 20, 80, 0.5),
                -3px 0 rgba(0, 255, 210, 0.5);
    transform: translateX(2px) skewX(1deg);
  }
  87% {
    text-shadow: -2px 0 rgba(255, 20, 80, 0.3),
                  2px 0 rgba(0, 255, 210, 0.3);
    transform: translateX(-1px);
  }
  88% {
    text-shadow: 0 0 40px rgba(0, 190, 230, 0.45),
                 0 0 90px rgba(0, 155, 210, 0.2);
    transform: none;
  }
}


/**** MOTION DISABLING FOR ACCESSIBILITY ****/

@media (prefers-reduced-motion: reduce) {
  h1,
  .myname {
    animation: none;
    transition: none;
  }
}



/**** THE SNAZZY NAVBAR BORDER SHENANNIGANS ****/
.navbar {
	--angle: 0deg;
	border-bottom: 3px solid;
	border-top: none !important;
	border-left: none !important;
	border-right: none !important;
	border-image: conic-gradient(from var(--angle), magenta, magenta, cyan, cyan, magenta) 1;
	animation: 10s rotate linear infinite;
}
.navbar-toggler {
	background-color: #303030 !important;
}




/**** THE SNAZZY HERO VIDEO BANNER ****/
#hero {
	height: 100vh;
	width: 100%;
	background: #fcfcfc;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 38em;
}
#hero::after {
	width: 100%;
	height: 100%;
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	background: rgba(0,0,0,0.25);
	z-index: 10;
	min-height: 38em;
}
#hero video {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 5;
	object-fit: cover;
	font-family: 'object-fit: cover';
	min-height: 38em;
}

#hero .texture {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 15;
	background:url("images/structure/exclusive-paper-enhanced.png");
	/*background-attachment: fixed;*/
	opacity: 0.3;
	min-height: 38em;
}



#hero .caption {
	z-index: 20;
	position: relative;
	text-align: center;
	color: #fff;
	margin-top: -20px;
}
@media only screen and (max-width: 600px) {
	.slashslash{
		background-image: none;
	}
	.jobtitle-left{
		padding-right: 0px;
		display: block;
	}
	.jobtitle-right{
		padding-left: 0px;
		display: block;
	}
}
@media only screen and (min-width: 601px) {
	.slashslash{
		background-image: url("images/structure/slashslash.png");
		background-repeat: no-repeat;
		background-position: 50% center;
		background-size: 44px 50px;
	}
	.jobtitle-left{
		padding-right: 14px;
		display: inline;
	}
	.jobtitle-right{
		padding-left: 14px;
		display: inline;
	}
}
.downscroll {
	padding-top: 1.6em;
	padding-bottom: 2em;
	align-self: flex-end;
	animation-duration: 3s;
	animation-iteration-count: infinite;
	margin: 0 auto 0 auto;
	transform-origin: bottom;
}
.bounceybounceyboingboing {
	animation-name: bounceybounceyboingboing;
	animation-timing-function: ease;
}
@keyframes bounceybounceyboingboing {
	0% {
		transform: translateY(0);
	}
	10% {
		transform: translateY(-15px);
	}
	20% {
		transform: translateY(0);
	}
	100% {
		transform: translateY(0);
	}
}
@media screen and (max-width: 768px) {
	video {
		display: none;
	}
	#hero {
		background: url('images/structure/hero-mobile.jpg') no-repeat;
		background-size: cover;
		height: 88vh;
		width: 100%;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	#hero .texture {
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
		z-index: 15;
		background:url("images/structure/exclusive-paper-enhanced.png");
		background-attachment: fixed;
		opacity: 0.7;
	}
	#hero::after {
		display: none;
	}
}



/***** THE INTRO SECTION *****/
.introduction {
	margin-top: 20px;
	padding-top: 20px;
	padding-bottom: 30px;
}
/* Small devices (portrait tablets and large phones, 600px and up) */
@media only screen and (min-width: 600px) {
	.introduction {
		background-image: none;
		background-position: 10% 15%;
		background-repeat: no-repeat;
	}
	.introphoto {
		display: block;
		text-align: center;
	}
}
/* Medium devices (landscape tablets, 768px and up) */
@media only screen and (min-width: 768px) {
	.introduction {
		background-image: url("images/structure/introbg-med.jpg");
		background-position: 110% 5%;
		background-repeat: no-repeat;
		height: 500px;
		margin-top:50px;
		padding-top: 50px;
	}
	.introphoto {
		display: none;
	}
}
/* Large devices (laptops/desktops, 992px and up) */
@media only screen and (min-width: 992px) {
	.introduction {
		background-image: url("images/structure/introbg.jpg");
		background-position: 40% 15%;
		background-repeat: no-repeat;
		height: 500px;
		margin-top:50px;
		padding-top: 50px;
	}
	.introphoto {
		display: none;
	}
}
/* Extra large devices (large laptops and desktops, 1200px and up) */
@media only screen and (min-width: 1200px) {
	.introduction {
		background-image: url("images/structure/introbg.jpg");
		background-position: 40% 15%;
		background-repeat: no-repeat;
		height: 500px;
		margin-top:50px;
		padding-top: 50px;
	}
	.introphoto {
		display: none;
	}
}
/* Extra large devices (large laptops and desktops, 1400px and up) */
@media only screen and (min-width: 1400px) {
	.introduction {
		background-image: url("images/structure/introbg.jpg");
		background-position: 50% 15%;
		background-repeat: no-repeat;
		height: 500px;
		margin-top:50px;
		padding-top: 50px;
	}
	.introphoto {
		display: none;
	}
}



/***** THE SNAZZY DECORATIVE FLOATY BIT *****/


/*@media only screen and (min-width: 993px) {
	.framedecoration {
		z-index: 1984;
		height: 345px;
		width: 275px;
		background-image: url("images/structure/framedecoration.png");
		background-repeat: no-repeat;
		margin-top: -130px;
		float: right;
	}
}
*/
@media only screen and (min-width: 993px) {
	.framedecoration {
		z-index: 1984;
		height: 280px;
		width: 240px;
		background-image: url("images/structure/framedecoration.png");
		background-repeat: no-repeat;
		background-size: cover;
		margin-top: -130px;
		margin-right: 100px;
		float: right;
	}
}
@media only screen and (max-width: 992px) {
	.framedecoration {
		display: none;
	}
}



/***** THE STUFF I'M GOOD AT SECTION *****/
/* Small devices (portrait tablets and large phones, 600px and up) */
@media only screen and (max-width: 600px) {
	.goodatstuff {
		background-image: url("images/structure/goodatbg-sm.jpg");
		background-repeat: no-repeat;
		background-size: cover;
	}
}
/* Medium devices (landscape tablets, 768px and up) */
@media only screen and (min-width: 601px) {
	.goodatstuff {
		background-image: url("images/structure/goodatbg-sm.jpg");
		background-repeat: no-repeat;
		background-size: cover;
	}
	.goodatstuffitems {
		display: flex !important;
	}
}
/* Large devices (laptops/desktops, 992px and up) */
@media only screen and (min-width: 992px) {
	.goodatstuff {
		background-image: url("images/structure/goodatbg.jpg");
		background-repeat: no-repeat;
		background-size: cover;
	}
	.goodatstuffitems {
		display: flex !important;
	}
}
/* Extra large devices (large laptops and desktops, 1200px and up) */
@media only screen and (min-width: 1200px) {
	.goodatstuff {
		background-image: url("images/structure/goodatbg.jpg");
		background-repeat: no-repeat;
		background-size: cover;
	}
	.goodatstuffitems {
		display: flex !important;
	}
}
/* Extra large devices (large laptops and desktops, 1400px and up) */
@media only screen and (min-width: 1400px) {
	.goodatstuff {
		background-image: url("images/structure/goodatbg.jpg");
		background-repeat: no-repeat;
		background-size: cover;
	}
	.goodatstuffitems {
		display: flex !important;
	}
}
.flex-container {
	display: flex;
	margin-top: 15px;
	flex-direction: column;
	margin-bottom: 2em;
}
@media only screen and (min-width: 992px) {
	.flex-container {
		flex-direction: row;
	}
	.skills-pic {
		width: 200px;
		margin-right: 10px;
		margin-left: -25px;
	}
	.skills-text {
		width: auto;
		padding-bottom: 2em;
	}
	@media only screen and (min-width: 1400px) {
		.skills-text {
			padding-top: 2em;
		}
	}
	@media only screen and (min-width: 1200px) {
		.skills-text {
			padding-top: 1.5em;
		}
	}
}
@media only screen and (max-width: 600px) {
	.skills-text {
		width: auto;
		padding-left: 8.333%;
		padding-bottom: 2em;
	}
}
@media only screen and (max-width: 768px) {
	.skills-item {
	text-align: center;
	}
}





.skills ul {
	list-style: none outside;
	padding-left: 0px;
}
.skills ul li {
	font-size: 0.75em;
	color: #d7d7d7;
	border-bottom: 1px solid #757575;
	padding: 10px 0;
	margin: 0;
}
.additionalskills {
	margin-bottom: 2em;
}



/***** THE WORK SHOWCASE *****/

.showcase {
	/*background-image: url("images/structure/myworkbg.jpg");*/
	background-repeat: no-repeat;
	background-position: bottom;
}

@media only screen and (min-width: 992px) {
	.carousel-inner{
	padding-left: 50px;
	padding-right: 50px;
	}
}

.featuredthumbnail {
	border-radius: 8px;
	border: 3px solid #ffffff;
	display: block;
	box-shadow: rgba(50, 50, 93, 0.25) 0px 13px 27px -5px, rgba(0, 0, 0, 0.3) 0px 8px 16px -8px;
	-webkit-transition : border 500ms ease-out; 
	-moz-transition : border 500ms ease-out;
	-o-transition : border 500ms ease-out;
}


.featuredthumbnail:hover {
	border-radius: 8px;
	border: 3px solid #00aeef;
	display: block;
	box-shadow: rgba(50, 50, 93, 0.25) 0px 13px 27px -5px, rgba(0, 0, 0, 0.3) 0px 8px 16px -8px;
}




.worktitle {
	font-size: 18px;
	font-weight: bold;
	margin-bottom: auto;
	margin-top: 15px;
	margin-left: 10px;
}
.clientname {
	font-size: 18px;
	margin-bottom: 10px;
	margin-left: 10px;
}
.linktocasestudy {
	font-size: 18px;
	margin-bottom: 20px;
	margin-left: 10px;
}



.generalthumbnail {
	border-radius: 8px;
	/*border: 3px solid #ffffff;*/
	filter: drop-shadow(0 20px 13px rgb(0 0 0 / 0.03)) drop-shadow(0 8px 5px rgb(0 0 0 / 0.08));

}









/**** THE TESTIMONIAL SECTION (POWERED BY FLICKITY) ****/
.testimonialsection {
	background-image: url("images/structure/goodatbg-sm.jpg");
	background-repeat: no-repeat;
	background-size: cover;
}

/* Medium devices (landscape tablets, 768px and up) */
@media only screen and (min-width: 601px) {
.testimonialsection {
	background-image: url("images/structure/goodatbg-sm.jpg");
	background-repeat: no-repeat;
	background-size: cover;
}
}
/* Large devices (laptops/desktops, 992px and up) */
@media only screen and (min-width: 992px) {
.testimonialsection {
	background-image: url("images/structure/goodatbg.jpg");
	background-repeat: no-repeat;
	background-size: cover;
}
}
/* Extra large devices (large laptops and desktops, 1200px and up) */
@media only screen and (min-width: 1200px) {
.testimonialsection {
	background-image: url("images/structure/goodatbg.jpg");
	background-repeat: no-repeat;
	background-size: cover;
}
}
/* Extra large devices (large laptops and desktops, 1400px and up) */
@media only screen and (min-width: 1400px) {
.testimonialsection {
	background-image: url("images/structure/goodatbg.jpg");
	background-repeat: no-repeat;
	background-size: cover;
}
}
.testimonial {
font-size: var(--fs-400);
padding: 2rem;
box-shadow: 0 0 1rem 0 rgba(0, 0, 0, .2);
border: 2px solid;
border-left-color: rgba(255,255,255,0.3);
border-right-color: rgba(255,255,255,0.4);
border-bottom-color: rgba(255,255,255,0.3);
border-top-color: rgba(255,255,255,0.5);
border-radius: 5px;
background-color: rgba(255, 255, 255, .15);
backdrop-filter: blur(5px);
}
.textimonialbox {
min-width: 300px;
/*background-color: #fafafa;
*/
}
.cell-content {
padding: 30px;
margin-bottom: 10px;
}
.flickity-enabled {
position: relative;
}
.flickity-enabled:focus {
outline: none;
}
.flickity-viewport {
overflow: hidden;
position: relative;
height: 101%;
}
.flickity-slider {
position: absolute;
width: 100%;
height: 100%;
}
/* draggable */
.flickity-enabled.is-draggable {
-webkit-tap-highlight-color: transparent;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
.flickity-enabled.is-draggable .flickity-viewport {
cursor: move;
cursor: -webkit-grab;
cursor: grab;
}
.flickity-enabled.is-draggable .flickity-viewport.is-pointer-down {
cursor: -webkit-grabbing;
cursor: grabbing;
}
/* ---- flickity-button ---- */
.flickity-button {
position: absolute;
background: hsla(0, 0%, 100%, 0);
border: none;
color: #fcfcfc;
/*direction: none !important;*/
}
.flickity-button:hover {
/*background: white;
*/
cursor: pointer;
}
.flickity-button:focus {
outline: none;
/*box-shadow: 0 0 0 2px #19F;*/
	opacity: 1;
}
.flickity-button:active {
opacity: 0.7;
}
.flickity-button:disabled {
opacity: 0.2;
cursor: auto;
pointer-events: none;
}
.flickity-button-icon {
fill: currentColor;
}
/* ---- previous/next buttons ---- */
.flickity-prev-next-button {
top: 50%;
width: 1px;
height: 1px;
border-radius: 50%;
/* vertically center */
transform: translateY(-50%);
}
.flickity-prev-next-button.previous {
left: 10px;
background-image: url("images/structure/carousel-left.png") !important;
background-size: cover !important;
width: 40px;
height: 40px;
}
.flickity-prev-next-button.next {
right: 10px;
background-image: url("images/structure/carousel-right.png") !important;
background-size: cover !important;
width: 40px;
height: 40px;
}
/* right to left */
.flickity-rtl .flickity-prev-next-button.previous {
left: auto;
right: 10px;
}
.flickity-rtl .flickity-prev-next-button.next {
right: auto;
left: 10px;
}
.flickity-prev-next-button .flickity-button-icon {
position: absolute;
left: 20%;
top: 20%;
width: 60%;
height: 60%;
display: none !important;
}
/* ---- page dots ---- */
.flickity-page-dots {
position: absolute;
width: 100%;
bottom: -25px;
padding: 0;
margin: 0;
list-style: none;
text-align: center;
line-height: 1;
}
.flickity-rtl .flickity-page-dots {
direction: rtl;
}
.flickity-page-dots .dot {
display: inline-block;
width: 10px;
height: 10px;
margin: 0 8px;
background: #fcfcfc;
border-radius: 50%;
opacity: 0.25;
cursor: pointer;
}
.flickity-page-dots .dot.is-selected {
opacity: 1;
}

/* Testimonials Carousel */
.carousel {
/*background: #FAFAFA;
*/
margin-bottom: 30px;
counter-reset: carousel-cell;
}
.carousel-cell {
width: 80%;
/*height: 300px;
*/
height: auto;
margin-right: 10px;
margin-bottom: 10px;
min-height: 100%;
box-shadow: 0 0 1rem 0 rgba(0, 0, 0, .2);
border: 2px solid;
border-left-color: rgba(256,256,256,0.3);
border-right-color: rgba(256,256,256,0.4);
border-bottom-color: rgba(256,256,256,0.3);
border-top-color: rgba(256,256,256,0.5);
border-radius: 5px;
background-color: rgba(255, 255, 255, .15);
backdrop-filter: blur(3px);
display: flex;
align-items: stretch;
opacity: 0.2;
}
@media only screen and (min-width: 991px) {
.carousel-cell {
	width: 60%;
}
}
.carousel-cell.is-selected {
-webkit-animation: fadeInFocus 0.8s ease-out;
-moz-animation: fadeInFocus 0.8s ease-out;
-o-animation: fadeInFocus 0.8s ease-out;
animation: fadeInFocus 0.8s ease-out;
opacity: 1.0;
}
@-webkit-keyframes fadeInFocus {
0% {
	display: none;
	opacity: 0.2;
}
1% {
	display: block;
	opacity: 0.2;
}
100% {
	display: block;
	opacity: 1;
}
}
@-moz-keyframes fadeInFocus {
0% {
	display: none;
	opacity: 0.2;
}
1% {
	display: block;
	opacity: 0.2;
}
100% {
	display: block;
	opacity: 1;
}
}
@-o-keyframes fadeInFocus {
0% {
	display: none;
	opacity: 0.2;
}
1% {
	display: block;
	opacity: 0.2;
}
100% {
	display: block;
	opacity: 1;
}
}
@keyframes fadeInFocus {
0% {
	display: none;
	opacity: 0.2;
}
1% {
	display: block;
	opacity: 0.2;
}
100% {
	display: block;
	opacity: 1;
}
}
.flickity-enabled .carousel-cell {
margin-bottom: 0;
}
/*.carousel-cell:before,.carousel-cell__number {
display: block;
width: 100px;
margin: 0 auto;
content: counter(carousel-cell);
text-align: center;
line-height: 160px;
font-size: 80px;
color: white;
}
*/
.testimonial-container {
display: flex;
/*margin-top: 15px;*/
flex-direction: column;
/*margin-bottom: 2em;
*/
}
@media only screen and (min-width: 768px) {
.testimonial-container {
	flex-direction: row;
}
.theirpic {
	/*width: 200px;
	margin-right: 10px;
	margin-left: -25px;
	*/
}
.theirname {
	width: auto;
	/*padding-bottom: 2em;
	*/
}
@media only screen and (min-width: 768px) {
	.testimonial .theirpic {
	}
	.testimonial .theirname {
	}
}
@media only screen and (min-width: 1200px) {
	.theirname {
		padding-top: 1em;
	}
}
}






/***** THE ABOUT ME INTRO SECTION *****/
.aboutmeintro {
	margin-top: 20px;
	padding-top: 20px;
	padding-bottom: 30px;
}
/* Small devices (portrait tablets and large phones, 600px and up) */
@media only screen and (min-width: 600px) {
	.aboutmeintro {
		background-image: none;
		background-position: 10% 15%;
		background-repeat: no-repeat;
	}
	.introphoto {
		display: block;
		text-align: center;
	}
}
/* Medium devices (landscape tablets, 768px and up) */
@media only screen and (min-width: 768px) {
	.aboutmeintro {
		/*background-image: url("images/structure/introbg-med.jpg");*/
		background-position: 110% 5%;
		background-repeat: no-repeat;
		/*height: 500px;*/
		margin-top:50px;
		padding-top: 50px;
	}
	.introphoto {
		display: none;
	}
}
/* Large devices (laptops/desktops, 992px and up) */
@media only screen and (min-width: 992px) {
	.aboutmeintro {
		/*background-image: url("images/structure/introbg.jpg");*/
		background-position: 40% 15%;
		background-repeat: no-repeat;
		/*height: 500px;*/
		margin-top:50px;
		padding-top: 50px;
	}
	.introphoto {
		display: none;
	}
}
/* Extra large devices (large laptops and desktops, 1200px and up) */
@media only screen and (min-width: 1200px) {
	.aboutmeintro {
		/*background-image: url("images/structure/introbg.jpg");*/
		background-position: 40% 15%;
		background-repeat: no-repeat;
		/*height: 500px;*/
		margin-top:50px;
		padding-top: 50px;
	}
	.introphoto {
		display: none;
	}
}
/* Extra large devices (large laptops and desktops, 1400px and up) */
@media only screen and (min-width: 1400px) {
	.aboutmeintro {
		/*background-image: url("images/structure/introbg.jpg");*/
		background-position: 50% 15%;
		background-repeat: no-repeat;
		/*height: 500px;*/
		margin-top:50px;
		padding-top: 50px;
	}
	.introphoto {
		display: none;
	}
}




/***** THE MY INTERESTS SECTION *****/
.myinterests {
	background-image: url("images/structure/interestsbg.jpg");
	background-repeat: no-repeat;
	background-position: top;
	background-size: cover;
}
@media only screen and (max-width: 768px) {
	.myinterests {
	background-image: url("images/structure/interestsbg.jpg");
	background-repeat: no-repeat;
	background-position: bottom;
	}
}

.interesttitle {
	font-size: 18px;
	font-weight: bold;
	margin-bottom: auto;
	text-align: center;
	margin-top: -35px;
}





/**** THE MY WORK PAGE *****/

.clearfix::after {
  content: "";
  clear: both;
  display: table;
}

.isactive, .btn:hover {
  background-color: #2a2a2a;
  color: #7fd6f7;
}

.grid-item{
	padding: 10px;
}

@media only screen and (max-width: 768px) {
	.makefluidonmobile {
		    max-width: 100%;
			height: auto;
	}
}

.btn-pad {
	padding-right: 0.3rem !important;
    padding-left: 0.3rem !important;
}

/**** CASE STUDIES ELEMENTS *****/
.breadcrumb {
	padding-top: 1em!important;
	padding-bottom: 1em!important;
	padding-left: 0.5rem!important;
	font-size: .8em!important;
}

.breadcrumb a {
	color: #6c757d!important;	
}


.projectoverview {
	font-family: 'Anton','Open Sans', sans-serif !important;
	font-size: 1.15em !important;
	text-transform: uppercase;
	margin-bottom: -15px;
}
.projectspecs {
	
}

.projectdetails {
	padding-top: 12px;
	padding-bottom: 12px;
}

@media (min-width: 1399px) { 
	.projectoverviewsection {
		margin-top: 6em;
	}
}
@media (min-width: 1200px) and (max-width: 1398.98px) {
		.projectoverviewsection {
		margin-top: 4em;
	}
}
@media (min-width: 992px) and (max-width: 1199.98px) {
		.projectoverviewsection {
		margin-top: 2.5em;
	}
}
@media (max-width: 767.98px)  {
		.projectoverviewsection {
		margin-top: 1.5em;
	}
}

/*** MISCELLANEOUS ****/

.shadowme {
filter: drop-shadow(0px 10px 18px #969696);
	}
	
	
	
	
	