/*   
Theme Name: bywill
Theme URI: www.bywill.co.uk
Description: Custom theme
Author: 
Author URI: 
Version: 1.0
Tags: blue, white, light, right-sidebar, fixed-width
License: GNU General Public License v2.0
License URI: http://www.gnu.org/licenses/gpl-2.0.html
*/
@import url('reset.css');
@import url('grid.css');
/* Default font settings. */
html {	font-size:100.01%;}
body {
	font-size: 16px;
	line-height: 22px;
	color: #414042;
	background: #fff;
	font-family: 'Work Sans', sans-serif;
	font-weight: 400;
}

/* font weights 400, 500, 600 */

/* Headings */
h1 {
	font-size: 60px;
	font-weight: 600;
	margin-bottom: 20px;
	line-height: 64px;
	color: #faa41a;
}
h2 {
	font-size: 26px;
	line-height: 34px;
	margin-bottom: 20px;
	font-weight: 400;
	color: #faa41a;
}
h3 {
	font-size: 20px;
	line-height: 26px;
	margin-bottom: 15px;
	font-weight: 600;
	color: #faa41a;
}
h4 {
	font-size: 30px;
	line-height: 40px;
	margin-bottom: 20px;
	font-weight: 400;
}

footer h3 {
	font-size: 20px;
	line-height: 28px;
	margin-bottom: 10px;
	font-weight: 400;
	color: #faa41a;
}

h1 img, h2 img, h3 img, h4 img, h5 img, h6 img {
	margin: 0;
}
/* Text elements */::-moz-selection{ background: #06F; color:#fff; text-shadow: none; }::selection { background:#06F; color:#fff; text-shadow: none; }
p {
	margin: 0 0 15px;
	font-size: 16px;
	line-height: 1.5em;
}
p img.left {
	float: left;
	margin: 15px 15px 15px 0;
	padding: 0;
}
p img.right {
	float: right;
	margin: 15px 0 15px 15px;
}
img {
	max-width: 100%;
	height: auto;
}
blockquote {
	margin: 15px;
	color: #666;
	font-style: italic;
}
strong {
	font-weight: bold;
}
em, dfn {
	font-style: italic;
}
dfn {
	font-weight: bold;
}
sup, sub {
	line-height: 0;
}
abbr, acronym {
	border-bottom: 1px dotted #ccc;
}
address {
	margin: 0 0 15px;
	font-style: italic;
}
del {
	color:#ccc;
}
pre {
	margin: 15px 0;
	white-space: pre;
}
pre, code, tt {
	font: 14px 'andale mono', 'lucida console', monospace;
	line-height: 20px;
}
hr {
	border-style: none;
	border-bottom: 1px solid #cfcfcf;
	margin-top: 40px;
	margin-bottom: 40px;
}
hr.foot {
	margin-top: 30px;
	margin-bottom: 30px;
}
/* Lists */
ol #commentlist {
    margin: 0px 0px 10px 0px;
}
#commentlist li {
    margin: 0px 0px 10px 0px;
    padding: 0px 0px 10px 0px;
	border-bottom: 1px dotted #ccc;
}
li ul, li ol {
	margin: 0;
}
ul, ol {
	margin: 0 15px 15px 0;
	padding-left: 20px;
}
nav ul, #sidebar ul {
	list-style-type: none;
    padding: 0px;
    margin: 0px 0px 10px 0px;
}
nav ul li {
	float: left;
}	
#sidebar li {
	list-style-type: none;
    padding: 0px;
    margin: 0px;
}
ul {
	list-style-type: disc;
}
ol {
	list-style-type: decimal;
}
dl {
	margin: 0 0 15px 0;
}
dl dt {
	font-weight: bold;
}
dd {
	margin-left: 20px;
}
/* Tables */
table {
	margin-bottom: 20px;
	width:100%;
}
th {
	font-weight: bold;
}
thead th {
	background: #c3d9ff;
}
th, td, caption {
	padding: 4px 10px 4px 5px;
}
tr.even td {
	background: #e5ecf9;
}
tfoot {
	font-style: italic;
}
caption {
	background: #eee;
}
/* Misc classes */
.small {
	font-size: 10px;
	margin-bottom: 8px;
	line-height: 18px;
}
.large {
	font-size: 19px;
	line-height: 19px;
	margin-bottom: 20px;
}
.hide {
	display: none;
}
.quiet {
	color: #888;
}
.loud {
	color: #000;
}

.added {
	background:#060;
	color: #fff;
}
.removed {
	background:#900;
	color: #fff;
}
.first {
	margin-left:0;
	padding-left:0;}
.last {
	margin-right:0;
	padding-right:0;
}
.top {
	margin-top:0;
	padding-top:0;
}
.bottom {
	margin-bottom:0;
	padding-bottom:0;
}
.postmetadata {
      margin: 0px 0px 0px 0px;
      padding: 0px 0px 30px 0px;
}
.meta {
      font-size: 10px;
}
/* --------------------------------------------------------------
   forms
   * Sets up some default styling for forms
   * Gives you classes to enhance your forms
   Usage:
   * For text fields, use class .title or .text
   * For inline forms, use .inline (even when using columns)
-------------------------------------------------------------- */
label {
	font-weight: bold;
}
fieldset {
	padding:22px;
	margin: 0 0 24px 0;
	border: 1px solid #ccc;
}
legend {
	font-weight: bold;
	font-size:19px;
}
/* Form fields */
input[type=text], input[type=password], input.text, input.title, textarea, select {
	background-color:#fff;
	border:1px solid #ccc;
	padding: 5px;
}
input[type=text]:focus, input[type=password]:focus, input.text:focus, input.title:focus, textarea:focus, select:focus {
	border-color:#777;
}
input[type=text], input[type=password], input.text, input.title, textarea, select {
	margin:8px 0;
}
input.text, input.title {
	max-width: 300px;
	width: 80%;
	padding:5px;
}
input.title {
	font-size:24px;
}
textarea {
	width: 600px;
	max-width: 90%;
	height: 150px;
	padding:5px;
}
input[type=checkbox], input[type=radio], input.checkbox, input.radio {
	position:relative;
	top:4px;
}
form.inline {
	line-height:3;
}
form.inline p {
	margin-bottom:0;
}
/* Success, notice and error boxes */
.error, .notice, .success {
	padding: 12px;
	margin-bottom: 16px;
	border: 2px solid #ddd;
}
.error {
	background: #FBE3E4;
	color: #8a1f11;
	border-color: #FBC2C4;
}
.notice {
	background: #FFF6BF;
	color: #514721;
	border-color: #FFD324;
}
.success {
	background: #E6EFC2;
	color: #264409;
	border-color: #C6D880;
}
.error a {
	color: #8a1f11;
}
.notice a {
	color: #514721;
}
.success a {
	color: #264409;
}
/* links */ 
a {
	color: #faa41a;
	text-decoration: none;
}
a:hover {
	text-decoration: underline;
}

.btn, .woocommerce #respond input#submit, .woocommerce a.button, .woocommerce button.button, .woocommerce input.button {
	background-color: #faa41a!important;
	color: #FFFFFF;
	border-radius: 10px;
	border: 3px solid #faa41a;
	line-height: 40px;
	padding: 0 40px;
	display: inline-block;
	transition: background 0.4s ease-in-out;
}

.btn:hover, .woocommerce #respond input#submit:hover, .woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover {
	color: #faa41a!important;
	background-color: #FFFFFF!important;
	text-decoration: none;
}
/* Misc */
.wp-caption {
	border: 1px solid #ddd;
	text-align: center;
	background-color: #f3f3f3;
	padding-top: 4px;
	margin: 10px;
	-moz-border-radius: 3px;
	-khtml-border-radius: 3px;
	-webkit-border-radius: 3px;
	border-radius: 3px;
}
.wp-caption img {
	margin: 0;
	padding: 0;
	border: 0 none;
}
.wp-caption-dd {
	font-size: 11px;
	line-height: 17px;
	padding: 0 4px 5px;
	margin: 0;
}
.wp-caption-text {
}
.aligncenter {
	display: block;
	margin-left: auto;
	margin-right: auto;
}
.alignleft {
	float: left;
	margin-right: 40px;
}
.alignright {
	float: right;
	margin-left: 40px;
}
.gallery-caption {
}
/* post */
.meta {
	word-wrap: break-word;
}
.sticky {
}
.bypostauthor {
}
/* Comments */#commentlist p {        margin: 0px;        font-size: 11px;}
#comments {
        margin:20px 0px 10px 0px;
        padding:20px 0px 10px 0px;
        border-top: solid 1px #ccc;
}
#postcomment {
        margin:20px 0px 10px 0px;
        padding:20px 0px 10px 0px;
        border-top: solid 1px #ccc;
}
/* --------------------------------------------------------------   
User Styles below here
-------------------------------------------------------------- 
*/

header .logo {
	text-align: center;
}

header .logo img {
	margin-top: 10px;
	width: 258px;
	height: auto;
	display: inline-block;
}

.wpml-ls-legacy-dropdown-click {
	position: fixed;
	z-index:10000;
}

.wpml-ls-legacy-dropdown-click a {
	border: none;
	background: #f4f5f5;
}

header .search {
	margin-top: 10px;
}

header .search input, header .search button {
	border: 1px solid transparent;
	background: transparent;
	line-height: 30px;
	text-align: right;
	padding: 0 5px;
	vertical-align: top;
}

header .search input:focus {
	border: 1px solid #f4f5f5;
	outline: none;
}

header .search button {
	color: #faa41a;
	font-size: 20px;
	cursor: pointer;
}

header nav {
	border-top: 1px solid #f4f5f5;
}

header nav > div > ul > li > a {
	color: #414042;
	font-size: 16px;
	line-height: 45px;
	padding: 0 18px;
	font-weight: 400;
	display: block;
}

header nav > div > ul > li > a:hover {
	text-decoration: none;
	color: #faa41a;
}

header nav > div > ul > li > ul {
	background: #414042;
	position: absolute;
	z-index: 1500;
	padding: 5px 0;
	display: none;
}

header nav > div > ul > li.menu-item-has-children:hover {
	background: #414042;
}

header nav > div > ul > li.menu-item-has-children:hover > a {
	color: #FFFFFF;
}

header nav > div > ul > li:hover > ul {
	display: block;
}

header nav > div > ul > li > ul > li {
	display: block;
	float: none;
}

header nav > div > ul > li > ul > li > a {
	display: block;
	padding: 0 20px;
	line-height: 30px;
	color: #FFFFFF;
	font-weight: 400;
	font-size: 16px;
}

header nav > div > ul > li > ul > li > a:hover {
	color: #faa41a;
	text-decoration: none;
}

.home-slider {
	width: 100%;
	height: 60vh;
	margin-bottom: 60px;
}

.home-slider .slide {
	width: 100%;
	height: 100%;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}

.home-slider .slide:after {
	display: block;
	content: '';
	position: absolute;
	top: 0px;
	left: 0px;
	right: 0px;
	bottom: 0px;
	background: rgb(2,0,36);
	background: linear-gradient(0deg, rgba(2,0,36,1) 0%, rgba(0,0,0,0.6811099439775911) 0%, rgba(0,0,0,0) 50%);
}

.home-slider .slide .overlay {
	text-align: center;
	color: #FFFFFF;
	position: absolute;
	bottom: 100px;
	left: 0px;
	right: 0px;
	z-index: 1500;
}

.home-slider .slide .overlay .title {
	font-weight: 400;
	font-size: 36px;
	line-height: 40px;
	margin-bottom: 15px;
}

.home-slider .slide .overlay .text {
	font-weight: 400;
	font-size: 18px;
	line-height: 22px;
}

.home-slider .cycle-next, .home-slider .cycle-prev {
	position: absolute;
	top: 0px;
	bottom: 0px;
	left: 0px;
	width: 100px;
	cursor: pointer;
	z-index: 600;
	color: #faa41a;
	font-size: 50px;
	display: flex;
  	justify-content: center;
  	align-items: center;
}

.home-slider .cycle-next {
	left: auto;
	right: 0px;
}

.home-slider .cycle-pager {
	position: absolute;
	bottom: 40px;
	left: 0px;
	right: 0px;
	text-align: center;
	z-index: 500;
}

.home-slider .cycle-pager span {
	color: transparent;
	background: #faa41a;
	border: 2px solid #faa41a;
	width: 10px;
	height: 10px;
	border-radius: 10px;
	cursor: pointer;
	margin: 5px;
	display: inline-block;
	box-shadow: 0px 0px 0px 2px #faa41a;
}

.home-slider .cycle-pager span.cycle-pager-active {
	border-color: #faa41a;
	background: #FFFFFF;
	box-shadow: 0px 0px 0px 2px #FFFFFF;
}

.signpost {
	display: block;
	position: relative;
	background: #414042;
	margin-bottom: 20px;
}

.signpost:hover {
	text-decoration: none;
}

.signpost img {
	display: block;
}

.signpost:hover img {
	opacity: 0.6;
}

.signpost .text {
	background: #FFFFFF;
	color: #414042;
	text-transform: uppercase;
	font-size: 24px;
	line-height: 30px;
	position: absolute;
	top: 0px;
	padding: 20px 60px;
	left: 50%;
	transform: translateX(-50%);
}

.signpost:hover .text {
	background: #414042;
	color: #FFFFFF;

}

.signpost .overlay {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translateX(-50%) translateY(-50%);
	color: #FFFFFF;
	border-top: 1px solid #FFFFFF;
	border-bottom: 1px solid #FFFFFF;
	font-size: 24px;
	line-height: 40px;
	padding: 0 60px;
	display: none;
	white-space: nowrap;
}

.signpost:hover .overlay {
	display: block;
}

.news-posts {
	margin: 60px 0;
}

.news-posts .news-post {
	background: #eef8f7;
	margin-bottom: 20px;
}

.news-posts .news-post .padded {

}

.news-posts .news-post .meta {
	margin-bottom: 10px;
}

.read-more {
	font-size: 35px;
}

.join-us {
	background-color: #271082;
	height: 260px;
	display: flex;
  	justify-content: center;
  	align-items: center;
  	position: relative;
}

.join-us img {
	display: block;
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0.4;
	z-index: 200;
}

.join-us .overlay {
	text-align: center;
	position: relative;
	z-index: 300;
}

.join-us .overlay h2 {
	color: #FFFFFF;
} 

.instagram {
	background: #eef8f7;
	padding: 40px 0;
}

.instagram h2 {
	color: #414042;
}

.highlight {
	padding: 40px 0;
	position: relative;
}

.highlight img {
	border-radius: 10px;
	margin-left: 10%;
}

.highlight .text {
	background: #271082;
	padding: 20px;
	border-radius: 10px;
	color: #FFFFFF;
	left: 55%;
	position: absolute;
	top: 50%;
	width: 300px;
	transform: translateY(-50%);
}

.featured-image img {
	width: 100%;
	height: 60vh;
	object-fit: cover;
	margin-bottom: 60px;
}

.wp-block-quote {
	padding-left: 100px;
	font-style: normal;
	position: relative;
}

.wp-block-quote p {
	font-size: 20px;
	line-height: 26px;
	color: #414042;
}

.wp-block-quote:before {
	display: block;
	position: absolute;
	background: url('images/quote.png') no-repeat;
	background-size: 50px 38px;
	width: 50px;
	height: 38px;
	left: 20px;
	top: 10px;
}

.wpml-ls-legacy-dropdown-click a span:before {
	content: 'View in ';
}

.news-posts {
	margin: 40px 0;
}

.news-posts .news-post {
	background: #eef8f7;
	padding: 10px;
}

.news-posts .news-post .thumb {
	position: relative;
	margin-bottom: 10px;
	display: block;
}

.news-posts .news-post .thumb span {
	position: absolute;
	top: 0px;
	left: 0px;
	background-color: #FFFFFF;
	padding: 5px 20px;
	display: block;
}

.news-posts .news-post .thumb span a {
	display: block;
	color: #414042;
}

.news-posts .news-post .thumb img {
	display: block;
}

.content .meta { 
	border-bottom: 1px solid #cfcfcf;
	border-top: 1px solid #cfcfcf;
	padding: 10px 0;
	margin-bottom: 15px;
	font-size: 16px;
}

.content .meta a {
	color: #414042;
} 

.sidebar h3 {
	color: #414042;
	border-bottom: 1px solid #cfcfcf;
}

.sidebar ul {
	list-style-type: none;
	padding: 0;
	margin: 0 0 20px 0;
}

.sidebar ul a {
	color: #414042;
}

.related.products {
	clear: both;
}

.home-signposts {
	margin-bottom: 60px;
}

header .search button {
	padding: 0 0 0px 5px;
}

.cart-header {
	text-align: right;
	padding-right: 7px;
}

.cart-header a {

}

.cart-header a div {
	display: inline-block;
}

.woocommerce div.product {
	padding-top: 20px;
}

footer {
	background: #eef8f7;
	padding: 40px 0;
	margin-top:60px;
}

footer .content {
	padding: 20px;
	background: #FFFFFF;
}

footer hr {
	margin-bottom: 5px;
}

footer .copy {
	font-size: 10px;
	line-height: 12px;
}

footer .footer-nav {
}

footer .footer-nav ul {
	float: right;
	list-style-type: none;
	margin: 0;
	padding: 0;
}

footer .footer-nav ul li {
	float: left;
	border-right: 1px solid #414042;
}

footer .footer-nav ul li:last-child {
	border-right: 0;
}

footer .footer-nav ul li a {
	font-size: 10px;
	color: #414042;
	line-height: 12px;
	display: block;
	padding: 0 5px;
}


@media all and (min-width: 980px) {

	.mobile {
		display: none;
	}
}
@media all and (max-width: 980px) and (min-width: 672px) {
	.full {
		display: none;
	}
	.mobile {
		display: none;
	}

}
@media all and (max-width: 672px) {
	.full, .no-mobile {
		display: none;
	}
	.mobile {
		display: block;
	}
	

	.wpml-ls-legacy-dropdown-click {
		margin: 0 auto;
	}

	header .logo img {
		margin-left: 50px;
	}

	header .search {
		text-align: center;
	}

	header .search input {
		text-align: left;
	}

	nav ul li {
		float: none;
	}

	.nav-btn {
		font-size: 40px;
		text-align: center;
		padding: 10px 0;
	}

	header nav > div > ul {
		display: none;
	}

	header nav li.menu-item-has-children {
		position: relative;
	}

	header nav > div > ul > li.menu-item-has-children:hover {
		background: transparent;
	}

	header nav > div > ul > li.menu-item-has-children:hover > a {
		color: #414042;
	}

	header nav li.menu-item-has-children:after {
		width: 0; 
	    height: 0; 
	    border-left: 8px solid transparent;
	    border-right: 8px solid transparent;
	    content: '';
	    border-top: 8px solid #414042;
	    display: block;
	    position: absolute;
	    right: 10px;
	    top: 20px;
	}

	header nav > div > ul > li > ul {
		position: relative;
		top: auto;
		left: auto;
		display: none;
	}

	header nav > div > ul > li:hover > ul {
		display: none;
	}

	h1 {
		font-size: 40px;
		line-height: 44px;
	}

	.btn, .woocommerce #respond input#submit, .woocommerce a.button, .woocommerce button.button, .woocommerce input.button {
		padding: 0 25px;
		font-size: 16px;
		line-height: 35px;
	}

	.home-slider, .featured-image img {
		height: 40vh;
	}

	.home-slider .slide .overlay .title, .home-slider .slide .overlay .text {
		display: none;
	}

	.highlight img {
		display: none!important;
	}

	.highlight .text {
		left: auto;
		top: auto;
		width: auto;
		position: relative;
		transform: none;
	}

	.cart-header {
		text-align: center;
		padding: 10px;
	}

	footer .footertwo {
		padding: 20px 0;
	}

	footer .footer-nav ul {
		float: none;
		margin-top: 10px;
	}
	
}
@media all and (max-width: 380px) {

	
}

/* --------------------------------------------------------------   
WooCommerce Styles below here
-------------------------------------------------------------- 
*/

.woocommerce ul.products li.product .woocommerce-loop-category__title, .woocommerce ul.products li.product .woocommerce-loop-product__title, .woocommerce ul.products li.product h3 {
    padding: .5em 0;
    margin: 0;
    font-size: 16px;
	line-height: 1em;
}