/**
* Stylesheet Name: J. Harold Williams
* Updated: October 24 2023 with Bootstrap v5.3.2
* Author: New England Small Business Consultants | nesbconsultants.com
*/

/*--------------------------------------------------------------
# General
--------------------------------------------------------------*/

body,
html {
	font-family: "Open Sans", sans-serif;
	color: #272829;
	height: 100%;
}

a {
	color: goldenrod;
	text-decoration: none;
}

a:hover {
	color: gold;
	text-decoration: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: "Raleway", sans-serif;
}

/*--------------------------------------------------------------
# Back to top button
--------------------------------------------------------------*/
.back-to-top {
	position: fixed;
	visibility: hidden;
	opacity: 0;
	right: 15px;
	bottom: 15px;
	z-index: 996;
	background: rgb(71, 169, 173); /* Mahryn Blue */
	width: 40px;
	height: 40px;
	border-radius: 50px;
	transition: all 0.4s;
}

.back-to-top i {
	font-size: 28px;
	color: #fff;
	line-height: 0;
}

.back-to-top:hover {
	background: #4c6d87; /* Mahryn Sea */
	color: #fff;
}

.back-to-top.active {
	visibility: visible;
	opacity: 1;
}

/*--------------------------------------------------------------
# Animations
--------------------------------------------------------------*/



/*--------------------------------------------------------------
# Header
--------------------------------------------------------------*/
#header {
	position: fixed;
	top: 0;
	left: 0;
	bottom: 0;
	width: 300px;
	transition: all ease-in-out 0.5s;
	z-index: 9997;
	transition: all 0.5s;
	padding: 0 15px;
	background: #040b14;
	overflow-y: auto;
}

#header .profile img {
	margin: 15px auto;
	display: block;
	width: 120px;
	border: 8px solid #2c2f3f;
}

#header .profile h1 {
	font-size: 24px;
	margin: 0;
	padding: 0;
	font-weight: 600;
	-moz-text-align-last: center;
	text-align-last: center;
	font-family: "Poppins", sans-serif;
}

#header .profile h1 a,
#header .profile h1 a:hover {
	color: #fff;
	text-decoration: none;
}

#header .profile .social-links a {
	font-size: 18px;
	display: inline-block;
	background: #212431;
	color: #fff;
	line-height: 1;
	padding: 8px 0;
	margin-right: 4px;
	border-radius: 50%;
	text-align: center;
	width: 36px;
	height: 36px;
	transition: 0.3s;
}

#header .profile .social-links a:hover {
	background: rgb(71, 169, 173);
	color: #fff;
	text-decoration: none;
}

#main {
	margin-left: 300px;
}

.container,
.container-fluid {
	padding-left: 30px;
	padding-right: 30px;
}

@media (max-width: 1199px) {
	#header {
		left: -300px;
	}

	#main {
		margin-left: 0;
	}

	.container,
	.container-fluid {
		padding-left: 12px;
		padding-right: 12px;
	}
}

/*--------------------------------------------------------------
# Navigation Menu
--------------------------------------------------------------*/

nav ul {
	height: 30em;
}

/* Desktop Navigation */
.nav-menu {
	padding: 30px 0 0 0;
}

.nav-menu * {
	margin: 0;
	padding: 0;
	list-style: none;
}

.nav-menu > ul > li {
	position: relative;
	white-space: nowrap;
}

.nav-menu a,
.nav-menu a:focus {
	display: flex;
	align-items: center;
	color: #a8a9b4;
	padding: 12px 15px;
	margin-bottom: 8px;
	transition: 0.3s;
	font-size: 15px;
}

.nav-menu a i,
.nav-menu a:focus i {
	font-size: 24px;
	padding-right: 8px;
	color: #6f7180;
}

.nav-menu a:hover,
.nav-menu .active,
.nav-menu .active:focus,
.nav-menu li:hover > a {
	text-decoration: none;
	color: #fff;
}

/* Navbar Dropdown*/
.dropdown-menu {
	min-height: 25em; /* Controls height of dropdown window */
}

.dropdown-menu a:hover,
.dropdown-menu .active,
.dropdown-menu .active:focus,
.dropdown-menu li:hover > a {
	text-decoration: none;
	color: #000;
}

.nav-menu a:hover i,
.nav-menu .active i,
.nav-menu .active:focus i,
.nav-menu li:hover > a i {
	color: #e4b612; /* Mahryn Gold */
}

/* Mobile Navigation */
.mobile-nav-toggle {
	position: fixed;
	right: 15px;
	top: 15px;
	z-index: 9998;
	border: 0;
	font-size: 24px;
	transition: all 0.4s;
	outline: none !important;
	background-color: rgb(71, 169, 173); /* Mahryn Blue */
	color: #fff;
	width: 40px;
	height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 0;
	border-radius: 50px;
	cursor: pointer;
}

.mobile-nav-active {
	overflow: hidden;
}

.mobile-nav-active #header {
	left: 0;
}

/*--------------------------------------------------------------
# Hero Section
--------------------------------------------------------------*/
#hero {
	width: 100%;
	height: 100vh;
	background-size: cover;
	background-position: center top;
}

.slider {
	overflow: hidden;
	width: 100vw;
	height: 100vh;
	position: relative;
	background-color: #000;
}

.slider .slide {
	position: absolute;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background-size: cover;
	background-position: center, center;
	/*-background-color: rgba(5, 13, 24, 0.3);-*/
	background-blend-mode: overlay;
	animation: slider 25.5s infinite;
}

/* Order of slides is "bottom up" so 1,6,5,4,3,2,1,repeat */

.slider .slide:nth-child(1) {
	background-image: url(../img/slider/mahryn_factory_background_1200x800.jpg);
	animation-delay: 0s;
}

.slider .slide:nth-child(2) {
	background-image: url(../img/slider/squamata_war_book3_covers_1200x800.png);
	animation-delay: -4.25s;
}

.slider .slide:nth-child(3) {
	background-image: url(../img/slider/varanus_background_1200x800.png);
	animation-delay: -8.5s;
}

.slider .slide:nth-child(4) {
	background-image: url(../img/slider/resurrection_book2_covers_1200x800.png);
	animation-delay: -12.75s;
}

.slider .slide:nth-child(5) {
	background-image: url(../img/slider/sadi_throne_room_background_1200x800.png);
	animation-delay: -17s;
}

.slider .slide:nth-child(6) {
	background-image: url(../img/slider/adira_book1_covers_1200x800.png);
	animation-delay: -21.25s;
}

@keyframes slider {
	0%,
	16%,
	100% {
		transform: translateX(0);
		animation-timing-function: ease;
	}
	17% {
		transform: translateX(-100%);
		animation-timing-function: step-end;
	}
	99% {
		transform: translateX(100%);
		animation-timing-function: ease;
	}
}

#hero .hero-container {
	position: relative;
	z-index: 2;
	min-width: 300px;
}

#hero h1 {
	margin: 0 0 10px 0;
	font-size: 64px;
	font-weight: 700;
	font-family: "Smythe", sans-serif;
	line-height: 56px;
	color: #fff;
}

#hero p {
	color: #fff;
	margin-bottom: 50px;
	font-size: 26px;
	font-family: "Smythe", sans-serif;
}

#hero p span {
	color: #fff;
	padding-bottom: 4px;
	letter-spacing: 1px;
	border-bottom: 3px solid rgb(71, 169, 173); /* Mahryn Blue */
}

@media (min-width: 1024px) {
	#hero {
		background-attachment: fixed;
	}
}

@media (max-width: 768px) {
	#hero h1 {
		font-size: 28px;
		line-height: 36px;
	}

	#hero h2 {
		font-size: 18px;
		line-height: 24px;
		margin-bottom: 30px;
	}
}

/*--------------------------------------------------------------
# Sections General
--------------------------------------------------------------*/
section {
	padding: 60px 0;
	overflow: hidden;
}

.section-bg {
	background: #f5f8fd;
}

.section-title {
	padding-bottom: 30px;
}

.section-title h2 {
	font-size: 32px;
	font-weight: bold;
	margin-bottom: 20px;
	padding-bottom: 20px;
	position: relative;
	color: #000000;
}

.section-title h2::after {
	content: "";
	position: absolute;
	display: block;
	width: 100%;
	height: 3px;
	background: #000000;
	bottom: 0;
	left: 0;
}

.section-title p {
	margin-bottom: 0;
}

/*--------------------------------------------------------------
# About
--------------------------------------------------------------*/
.about .content h3 {
	font-weight: 700;
	font-size: 26px;
	color: #173b6c;
}

.about .content ul {
	list-style: none;
	padding: 0;
}

.about .content ul li {
	margin-bottom: 20px;
	display: flex;
	align-items: center;
}

.about .content ul strong {
	margin-right: 10px;
}

.about .content ul i {
	font-size: 16px;
	margin-right: 5px;
	color: #149ddd;
	line-height: 0;
}

.about .content p:last-child {
	margin-bottom: 0;
}

/*--------------------------------------------------------------
# News Section
--------------------------------------------------------------*/
.news {
	padding-bottom: 130px;
}

.news .info {
	padding: 30px;
	background: #fff;
	width: 100%;
	box-shadow: 0 0 24px 0 rgba(0, 0, 0, 0.12);
}

.news .info i {
	font-size: 20px;
	color: #149ddd;
	float: left;
	width: 44px;
	height: 44px;
	background: #dff3fc;
	display: flex;
	justify-content: center;
	align-items: center;
	border-radius: 50px;
	transition: all 0.3s ease-in-out;
}

.news .info h4 {
	padding: 0 0 0 60px;
	font-size: 22px;
	font-weight: 600;
	margin-bottom: 5px;
	color: #050d18;
}

.news .info p {
	padding: 0 0 10px 60px;
	margin-bottom: 20px;
	font-size: 14px;
	color: #173b6c;
}

/*--------------------------------------------------------------
# Events Section
--------------------------------------------------------------*/
.events .events-title {
	font-size: 26px;
	font-weight: 700;
	margin-top: 20px;
	margin-bottom: 20px;
	color: #050d18;
}

.events .events-item {
	padding: 0 0 20px 20px;
	margin-top: -2px;
	border-left: 2px solid #1f5297;
	position: relative;
}

.events .events-item h4 {
	line-height: 18px;
	font-size: 18px;
	font-weight: 600;
	text-transform: uppercase;
	font-family: "Poppins", sans-serif;
	color: #050d18;
	margin-bottom: 10px;
}

.events .events-item h5 {
	font-size: 16px;
	background: #e4edf9;
	padding: 5px 15px;
	display: inline-block;
	font-weight: 600;
	margin-bottom: 10px;
}

.events .events-item ul {
	padding-left: 20px;
}

.events .events-item ul li {
	padding-bottom: 10px;
}

.events .events-item:last-child {
	padding-bottom: 0;
}

.events .events-item::before {
	content: "";
	position: absolute;
	width: 16px;
	height: 16px;
	border-radius: 50px;
	left: -9px;
	top: 0;
	background: #fff;
	border: 2px solid #1f5297;
}

.row-striped:nth-of-type(odd) {
	background-color: #efefef;
	border-left: 4px #000000 solid;
}

.row-striped:nth-of-type(even) {
	background-color: #ffffff;
	border-left: 4px #efefef solid;
}

.row-striped {
	padding: 15px 0;
}

/*--------------------------------------------------------------
# Map Section
--------------------------------------------------------------*/
#map {
	width: 100%;
	height: 100vh;
	background-size: cover;
	background-image: url(../img/maps/map_of_mahryn.jpg);
	background-position: center center;
	background-color: #000000;
	background-attachment: fixed;
	background-repeat: no-repeat;
}

#map:before {
	content: "";
	background: rgba(5, 13, 24, 0.3);
	position: absolute;
	bottom: 0;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1;
}

#map .map-container {
	position: relative;
	z-index: 2;
	min-width: 300px;
}

#map h1 {
	margin: 0 0 10px 0;
	font-family: "Smythe", sans-serif;
	font-size: 80px;
	font-weight: 700;
	line-height: 56px;
	color: #fff;
}

#map p {
	color: #fff;
	margin-bottom: 50px;
	font-size: 26px;
	font-family: "Smythe", sans-serif;
}

#map p span {
	color: #fff;
	padding-bottom: 4px;
	letter-spacing: 1px;
	border-bottom: 3px solid #149ddd;
}

@media (min-width: 1024px) {
	#map {
		background-attachment: fixed;
	}
}

@media (max-width: 768px) {
	#map h1 {
		font-size: 28px;
		line-height: 36px;
	}

	#map h2 {
		font-size: 18px;
		line-height: 24px;
		margin-bottom: 30px;
	}
}

/*--------------------------------------------------------------
# Lands (Zigzag) Section - Start
--------------------------------------------------------------*/
#zigzag.content-section {
	text-align: center;
	width: 100vw;
}

@media (min-width: 768px) {
	#zigzag.content-section {
		text-align: left;
	}
}

#zigzag.content-section p {
	display: block;
}

#zigzag.content-section-spacing {
	padding-top: 48px;
	padding-bottom: 48px;
}

@media (min-width: 768px) {
	#zigzag.content-section-spacing {
		padding-top: 80px;
		padding-bottom: 80px;
	}
}

.mahryn_gradient {
	background: rgb(148, 140, 126);
	background: linear-gradient(
		0deg in oklch,
		rgba(162, 0, 255, 1) 2%,
		rgba(132, 0, 255, 1) 50%,
		rgba(0, 0, 0, 1) 98%
	);
}

.mahryn_gradient_reverse {
	background: rgb(148, 140, 126);
	background: linear-gradient(
		0deg in oklch,
		rgba(0, 0, 0, 1) 2%,
		rgba(132, 0, 255, 1) 50%,
		rgba(162, 0, 255, 1) 98%
	);
}

.gridContainer {
	max-width: 1232px;
	margin: 0 auto;
	padding-right: 15px;
	padding-left: 15px;
	box-sizing: border-box;
}

@media only screen and (min-width: 1200px) {
	.gridContainer {
		width: 90%;
	}
}

@media only screen and (min-width: 1024px) {
	.gridContainer {
		width: 90%;
	}
}

@media only screen and (min-width: 768px) {
	.gridContainer {
		width: 90%;
	}
}

#zigzag > div {
	/* Applies the style to all direct child div elements of the #zigzag element */
	display: block;
}

#zigzag > div:after,
#zigzag > div:before {
	content: "";
	display: table;
	width: 0;
}

#zigzag > div:after {
	clear: both;
}

.zigzag_row {
	box-sizing: border-box;
	display: flex;
	-webkit-box-flex: 0;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-moz-box-flex: 0;
	flex: 0 1 auto;
	flex-direction: row;
	flex-wrap: wrap;
	margin-right: -15px;
	margin-left: -15px;
}

.zigzag_row > * {
	flex-basis: 100%;
	padding-right: 15px;
	padding-left: 15px;
}

.zigzag_row:after,
.zigzag_row:before {
	position: absolute;
}

#content_box h1 {
	color: #000000;
	font-family: "Smythe", sans-serif;
	margin-top: 1em;
}

#content_box p {
	color: #000000;
	font-family: "Smythe", sans-serif;
	display: block;
	margin-block-start: 1em;
	margin-block-end: 1em;
	margin-inline-start: 0px;
	margin-inline-end: 0px;
	unicode-bidi: isolate;
}

#content_box p:last-child {
	margin-bottom: 15px;
}

@media only screen and (max-width: 767px) {
	#content_box p {
		margin-left: 10px;
		margin-right: 30px;
	}
}

@media only screen and (min-width: 768px) {
	.col-sm-6 {
		box-sizing: border-box;
		-webkit-box-flex: 0;
		-webkit-flex-grow: 0;
		flex-grow: 0;
		-webkit-flex-shrink: 0;
		flex-shrink: 0;
		padding-right: 15px;
		padding-left: 15px;
		-webkit-flex-basis: 50%;
		flex-basis: 50%;
		max-width: 50%;
	}

	.col-sm-padding-large {
		padding: 6rem 10%;
	}
}

.flexbox,
.flexbox-strech {
	display: -webkit-box;
	display: -webkit-flex;
	display: flex;
}

.flexbox img {
	flex: 0 0 auto;
}

.flexbox-strech > * {
	flex-basis: 100%;
}

.middle-xs {
	-webkit-box-align: center;
	align-items: center;
}

.center-xs {
	-webkit-box-pack: center;
	justify-content: center;
	text-align: center;
}

.no-gutter-col {
	padding-left: 0;
	padding-right: 0;
}

.left-img,
.right-img {
	background-image: url(./img/places/mahryn_landscape_800x800.jpg);
	background-size: cover;
	height: 70%;
	min-height: 350px;
	z-index: 10;
}

.shadow-large {
	box-shadow: 0 10px 30px 0 rgba(189, 189, 189, 0.3),
		0 10px 30px rgba(0, 0, 0, 0.08);
}

@media (min-width: 768px) {
	.overlap-right-large {
		margin-right: -30%;
	}
	.overlap-left-large {
		margin-left: -30%;
	}
}

.content-col {
	background-color: rgb(255, 140, 0);
	background-image: url(/img/backgrounds/vintage_paper_350x500.jpg);
	background-size: cover;
}

/*--------------------------------------------------------------
# Lands (Zigzag) Section - End
--------------------------------------------------------------*/

/** Sample Break **/

#sample_break .separator {
	width: 100%;
}

.center-block {
	/* Centers divider image within separator div */
	display: block;
	margin-left: auto;
	margin-right: auto;
}

/* Add Bootstrap class="img-fluid" to make image responsive */

/*--------------------------------------------------------------
# Glossary and Acknowledgements Sections
--------------------------------------------------------------*/
.glossary {
	background-image: url(/img/backgrounds/mahryn_texture1_0002_vertical_1600x2162.png);
	background-size: cover;
	color: #fff;
}

.glossary h1 {
	font-weight: 900;
	text-align: center;
	font-family: "Smythe", sans-serif;
}

.glossary h3 {
	font-weight: 700;
	font-family: "Smythe", sans-serif;
}

.glossary p {
	font-weight: 400;
	font-family: "Smythe", sans-serif;
}

.glossary ul {
	font-weight: 400;
	font-family: "Smythe", sans-serif;
	list-style-type: circle;
}

.glossary .bio {
	margin-top: 5rem;
	margin-bottom: 5rem;
}

.glossary img {
	width: 150px;
	height: 200px;
	margin-top: 1rem;
	margin-left: 1rem;
	border-radius: 10px;
	float: right;
}

.bio .social-links a {
	font-size: 1.5rem;
	display: inline-block;
	background: transparent;
	color: #fff;
	line-height: 1.5;
	padding: 1.2rem 0;
	margin-right: 1.5rem;
	border-radius: 50%;
	text-align: center;
	width: 4rem;
	height: 4rem;
	transition: 0.3s;
}

.bio .social-links a:hover {
	background: rgb(106,77,119);
	color: #fff;
	transform: scale(1.5);
	text-decoration: none;
}


/*--------------------------------------------------------------
# Character Cards
--------------------------------------------------------------*/
.flex-container {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: space-evenly;
}

/* Responsive layout - makes a one column layout instead of a multi-column layout */
@media (max-width: 700px) {
	.flex-container {
		flex-direction: column;
		align-items: center;
	}
}

/* Width & Height must match image dimensions */
.card_container {
	width: 340px;
	height: 500px;
	perspective: 800px;
	padding: min(.5em, 1%);
}

.card_container:hover > .card {
	cursor: pointer;
	transform: rotateY(180deg);
}

.card {
	height: 100%;
	width: 100%;
	background-color: transparent;
	position: relative;
	transition: transform 1500ms;
	transform-style: preserve-3d;
}

.front,
.back {
	height: 100%;
	width: 100%;
	border-radius: 2rem;
	box-shadow: 0 0 5px 2px rgba(50, 50, 50, 0.25);
	position: absolute;
	backface-visibility: hidden;
}

.front img {
	border-radius: 2rem;
	box-shadow: 0 0 5px 2px rgba(50, 50, 50, 0.25);
}

.back {
	background-color: #767676; /* Mahryn Grey*/
	background-image: url(../img/backgrounds/vintage_paper_350x500.jpg);
	transform: rotateY(180deg);
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5rem;
}

.back h1 {
	color: #000000;
	font-family: "Smythe", sans-serif;
}

.back p {
	color: #000000;
	font-family: "Smythe", sans-serif;
	margin: 0px 15px 0px 15px;
}

/*--------------------------------------------------------------
# Portfolio
--------------------------------------------------------------*/
.portfolio .portfolio-item {
	margin-bottom: 30px;
}

.portfolio #portfolio-flters {
	padding: 0;
	margin: 0 auto 35px auto;
	list-style: none;
	text-align: center;
	background: #fff;
	border-radius: 50px;
	padding: 2px 15px;
}

.portfolio #portfolio-flters li {
	cursor: pointer;
	display: inline-block;
	padding: 10px 15px 8px 15px;
	font-size: 14px;
	font-weight: 600;
	line-height: 1;
	text-transform: uppercase;
	color: #272829;
	margin-bottom: 5px;
	transition: all 0.3s ease-in-out;
}

.portfolio #portfolio-flters li:hover,
.portfolio #portfolio-flters li.filter-active {
	color: #149ddd;
}

.portfolio #portfolio-flters li:last-child {
	margin-right: 0;
}

.portfolio .portfolio-wrap {
	transition: 0.3s;
	position: relative;
	overflow: hidden;
	z-index: 1;
}

.portfolio .portfolio-wrap::before {
	content: "";
	background: rgba(255, 255, 255, 0.5);
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	transition: all ease-in-out 0.3s;
	z-index: 2;
	opacity: 0;
}

.portfolio .portfolio-wrap .portfolio-links {
	opacity: 1;
	left: 0;
	right: 0;
	bottom: -60px;
	z-index: 3;
	position: absolute;
	transition: all ease-in-out 0.3s;
	display: flex;
	justify-content: center;
}

.portfolio .portfolio-wrap .portfolio-links a {
	color: #fff;
	font-size: 28px;
	text-align: center;
	background: rgba(20, 157, 221, 0.75);
	transition: 0.3s;
	width: 50%;
}

.portfolio .portfolio-wrap .portfolio-links a:hover {
	background: rgba(20, 157, 221, 0.95);
}

.portfolio .portfolio-wrap .portfolio-links a + a {
	border-left: 1px solid #37b3ed;
}

.portfolio .portfolio-wrap:hover::before {
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	opacity: 1;
}

.portfolio .portfolio-wrap:hover .portfolio-links {
	opacity: 1;
	bottom: 0;
}

/*--------------------------------------------------------------
# Portfolio Details
--------------------------------------------------------------*/
.portfolio-details {
	padding-top: 40px;
	/*background-image: url(../img/backgrounds/textured_ivory_bkg.jpg);*/
}

.portfolio-details .portfolio-details-slider img {
	width: 100%;
}

.portfolio-details .portfolio-details-slider .swiper-pagination {
	margin-top: 20px;
	position: relative;
}

.portfolio-details
	.portfolio-details-slider
	.swiper-pagination
	.swiper-pagination-bullet {
	width: 12px;
	height: 12px;
	background-color: #fff;
	opacity: 1;
	border: 1px solid #149ddd;
}

.portfolio-details
	.portfolio-details-slider
	.swiper-pagination
	.swiper-pagination-bullet-active {
	background-color: #149ddd;
}

.portfolio-details .portfolio-info {
	padding: 30px;
	box-shadow: 0px 0 30px rgba(5, 13, 24, 0.08);
	height: 100%;
	/*background-image: url(../img/backgrounds/textured_ivory_bkg.jpg);*/
}

.portfolio-details .portfolio-info h3 {
	font-size: 22px;
	font-weight: 700;
	font-family: "Smythe", sans-serif;
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid #eee;
}

.portfolio-details .portfolio-info p {
	padding: 0;
	font-family: "Smythe", sans-serif;
}

.portfolio-details .portfolio-info ul {
	list-style: none;
	padding: 0;
	font-size: 15px;
}

.portfolio-details .portfolio-info ul li + li {
	margin-top: 10px;
}

.portfolio-details .portfolio-description {
	padding-top: 30px;
}

.portfolio-details .portfolio-description h2 {
	font-size: 26px;
	font-weight: 700;
	margin-bottom: 20px;
	font-family: "Smythe", sans-serif;
}

.portfolio-details .portfolio-description p {
	padding: 0;
	font-family: "Smythe", sans-serif;
}

/*--------------------------------------------------------------
# Services
--------------------------------------------------------------*/
.services .icon-box {
	margin-bottom: 20px;
}

.services .icon {
	float: left;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 54px;
	height: 54px;
	background: #149ddd;
	border-radius: 50%;
	transition: 0.5s;
	border: 1px solid #149ddd;
}

.services .icon i {
	color: #fff;
	font-size: 24px;
	line-height: 0;
}

.services .icon-box:hover .icon {
	background: #fff;
}

.services .icon-box:hover .icon i {
	color: #149ddd;
}

.services .title {
	margin-left: 80px;
	font-weight: 700;
	margin-bottom: 15px;
	font-family: "Smythe", sans-serif;
	font-size: 20px;
}

.services .title a {
	color: #343a40;
}

.services .title a:hover {
	color: #149ddd;
}

.services .description {
	margin-left: 80px;
	line-height: 24px;
	font-size: 14px;
}

/*--------------------------------------------------------------
# Testimonials
--------------------------------------------------------------*/
.testimonials .testimonials-carousel,
.testimonials .testimonials-slider {
	overflow: hidden;
}

.testimonials .testimonial-item {
	box-sizing: content-box;
	text-align: center;
	min-height: 320px;
}

.testimonials .testimonial-item .testimonial-img {
	width: 150px;
	margin-top: 0;
	margin-right: auto;
	margin-bottom: 0px;
	margin-left: auto;
}

.testimonials .testimonial-item h3 {
	font-size: 18px;
	font-weight: bold;
	margin: 10px 0 5px 0;
	color: #111;
}

.testimonials .testimonial-item h4 {
	font-size: 14px;
	color: #999;
	margin: 0;
}

.testimonials .testimonial-item .quote-icon-left,
.testimonials .testimonial-item .quote-icon-right {
	color: #c3e8fa;
	font-size: 26px;
}

.testimonials .testimonial-item .quote-icon-left {
	display: inline-block;
	left: -5px;
	position: relative;
}

.testimonials .testimonial-item .quote-icon-right {
	display: inline-block;
	right: -5px;
	position: relative;
	top: -2px; /* Adjust to move quote graphic above or below line. */
	vertical-align: top; /* Added to correct last line height issue. */
}

.testimonials .testimonial-item p {
	font-style: italic;
	margin: 0 15px 15px 15px;
	padding: 20px;
	background: #fff;
	position: relative;
	margin-bottom: 35px;
	border-radius: 6px;
	box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.1);
}

.testimonials .testimonial-item p::after {
	content: "";
	width: 0;
	height: 0;
	border-top: 20px solid #fff;
	border-right: 20px solid transparent;
	border-left: 20px solid transparent;
	position: absolute;
	bottom: -20px;
	left: calc(50% - 20px);
}

.testimonials .swiper-pagination {
	margin-top: 20px;
	position: relative;
}

.testimonials .swiper-pagination .swiper-pagination-bullet {
	width: 12px;
	height: 12px;
	background-color: #fff;
	opacity: 1;
	border: 1px solid #149ddd;
}

.testimonials .swiper-pagination .swiper-pagination-bullet-active {
	background-color: #149ddd;
}

/*--------------------------------------------------------------
# Contact
--------------------------------------------------------------*/
.contact-info {

} 


.contact-info img{
	display: block;
	padding: min(.5em, 1%);
	margin-top: 5em;
	border-radius: 20px;
}

/* Style inputs with type="text", select elements and textareas */
input[type="text"],
select,
textarea {
	width: 100%; /* Full width */
	padding: 12px; /* Some padding */
	border: 1px solid #ccc; /* Gray border */
	border-radius: 4px; /* Rounded borders */
	box-sizing: border-box; /* Make sure that padding and width stays in place */
	margin-top: 6px; /* Add a top margin */
	margin-bottom: 16px; /* Bottom margin */
	overflow: auto;
	vertical-align: top;
	resize: vertical; /* Allow the user to vertically resize the textarea (not horizontally) */
}

input:invalid {
	border: 2px dashed red;
}

textarea:invalid {
	border: 2px dashed red;
}

input, select, textarea:invalid:required {
	background-image: linear-gradient(to right, pink, lightgreen);
}

input, select, textarea:valid {
	border: 2px solid black;
}


/* Style the submit button with a specific background color etc */
button[type="submit"] {
	background-color: rgb(71, 169, 173);  /* Mahryn Blue */
	color: white;
	padding: 12px 20px;
	border: none;
	border-radius: 4px;
	cursor: pointer;
}

/* When moving the mouse over the submit button, add a darker green color */
button[type="submit"]:hover {
	background-color: #4c6d87;  /* Mahryn Sea */
}

/* Add a background color and some padding around the form */

.form_container {
	border-radius: 10px;
	/*background-color: #f2f2f2;*/
	padding: 20px;
	box-shadow: 0 0 24px 0 rgba(0, 0, 0, 0.12);
}

/*--------------------------------------------------------------
# Breadcrumbs
--------------------------------------------------------------*/
.breadcrumbs {
	padding: 20px 0;
	background: #8505c4;
}

.breadcrumbs h2 {
	font-size: 26px;
	font-weight: 300;
	color: #fff;
}

.breadcrumbs ol {
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	padding: 0;
	margin: 0;
	font-size: 15px;
}

.breadcrumbs ol li + li {
	padding-left: 10px;
}

.breadcrumbs ol li + li::before {
	display: inline-block;
	padding-right: 10px;
	color: #0e2442;
	content: "/";
}

@media (max-width: 768px) {
	.breadcrumbs .d-flex {
		display: block !important;
	}

	.breadcrumbs ol {
		display: block;
	}

	.breadcrumbs ol li {
		display: inline-block;
	}
}

/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/
#footer {
	padding: 15px;
	color: goldenrod;
	font-size: 12px;
	position: fixed;
	left: 0;
	bottom: 0;
	width: 300px;
	z-index: 9999;
	background: #040b14;
}

#footer .copyright {
	text-align: center;
}

#footer .credits {
	padding-top: 5px;
	text-align: center;
	font-size: 13px;
	color: #eaebf0;
}

@media (max-width: 1199px) {
	#footer {
		position: static;
		width: auto;
		padding-right: 20px 15px;
	}
}
