
/************************************
			CSS VARIABLES
*************************************/
:root {
	--primary-bg: #B4CD34;
	--secondary-bg: #444;
	
	--primary-font-color: rgb(91, 98, 102);
	
	--footer-bg: #EDEDED;
	--footer-font-color: rgba(91, 98, 102, 0.7);
	
	/*--main-font: 'Open Sans', sans-serif;*/
	--nav-font-color: #fff;
}



html, body {
	font-family: 'Montserrat';
	color: rgba(91, 98, 102, 0.7);
	margin-left: 0px;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	text-align: justify;
	text-justify: inter-word;
	min-height: 100%;
	Width: 100%;

}

a{
	text-decoration: none;
}

.hidden {
	display:none;
}

/************************************
			Fonts/Colours
*************************************/

.header-font-light{
	font-weight:300;
	margin-bottom:0px;
	font-size:22px;
}

.header-font-telephone{
	font-weight:300;
	margin-top:0px;
	margin-left:2px;
	font-weight:normal;
	color: rgb(91, 98, 102);
	font-size:28px;
}

.GYSTable h3{
	background: #eee;
	padding-bottom: 15px;
	padding-top: 15px;
	margin-bottom: 2px;
    color:#004990;
}
.GYSTable, .GYSCategories{
	display: inline-block;
	position: relative;
	text-align: center;
}

.GYSCategories img, .GYSCategories {
	width: 400px;
	height: 65px;
}




@media only screen and (max-width: 768px) {
	.header-font-telephone{
		font-size:20px;
		
	}
	.header-font-light{
		font-size:16px;
	}
	
	.GYSCategories img, .GYSCategories {
		width: 300px;
		height: 48px;
	}
	
}

@media only screen and (max-width: 768px) {
	.header-font-telephone{
		font-size:16px;
		
	}
	.icon-4 {
		display: none;
	}
	.LoginHeadButton {
		display: none;
	}
	.SignUpHeadButton {
		display: none;
	}
	
}

/************************************
			Header
*************************************/

.header{
	width:90%;
	margin:auto;
	max-width:1200px;
	padding-top:1%;
	padding-bottom:1%;
	display: flex;
	justify-content: space-between;
	align-items:center;
}

.logo1 {
	height: 120px;
}

.icon-4 {
	height: 30px;
	width: 30px;
}

.header-top-banner{
	height: 40px;
	line-height:40px;
	background-color:#eee;
	text-align:center;
}

.LoginHeadButton {
	background: #b4cd34;
	border-radius: 2px;
	width: 70px;
	height: 30px;
	font-size: 12px;
	color: #FFFFFF;
	letter-spacing: 1px;
	font-weight: 700;
	border:0px;
	margin-right:5px;
}
	
.LoginHeadButton a {
	color: #FFFFFF;
}

.SignUpHeadButton {
	background: #5a6165;
	border-radius: 2px;
	width: 90px;
	height: 30px;
	font-size: 12px;
	color: #FFFFFF;
	letter-spacing: 1px;
	font-weight: 700;
	border:0px;
}
	
.SignUpHeadButton a {
	color: #FFFFFF;
}


/************************************
		Navigation
*************************************/

.topnav {
  display: flex;
  height: 60px;
  width: 100%;
  background-color: #ffffff;
  flex-direction: row;
  justify-content: space-evenly;
  align-content: center;
  flex-wrap: nowrap;

}

.topnav div {
  
  margin: 0px;
  flex: 1;
  text-align: center;
  vertical-align: middle;
  
  /*border: 2px solid red;*/
}

.child {
	display: flex;
	justify-content: center;
	flex-direction: column;
	text-align: center;
	height: 60px;
	background-color: #b4cd34;
	color:#fff;
	font-weight: 600;
}

.child:hover {
	background-color: #b5be00;
	color: #fff;
	text-decoration: none;
	font-weight: 600;
}

.topnav a {
  color: #fff;
  font-size: 16px;
  font-weight: 700;
}

.topnav a:hover {
	color: #fff;
	text-decoration: none;
	font-weight: 700;
}
	
.mobilenavicon{
    position:absolute;
    right:20px;
    top:77px;
    width:50px;
    background-repeat: no-repeat;
    height:50px;
    display:none;
    
}
.mobilenavicon img {
    width:100%;
    height:100%;
    cursor: pointer;
}
.mobilenavdropdown{
    position:absolute;
    top:180px;
    width:100%;
    background-color:rgba(0,0,0,0.9);
    z-index:50;
    display:none;
}
.mobilenavitem{
    height:50px;
    line-height:50px;
    width:100%;
    display:block;
    text-align: left;
    color:white;
    font-size:16px;
    padding-left:20px;
    cursor:pointer;
}
.mobilenavitem:hover{
    background-color:white!important;
    color:black;
	text-decoration:none;
}
.submenuitem{
    height:50px;
    display:block;
    width:100%;
    text-align:left;
    line-height:50px;
    color:white;
    font-size:14px;
    padding-left:50px;
    overflow:hidden;
}

@media only screen and (max-width: 800px) {
	.topnav {
		display: none;
	}
	.mobilenavicon{
		display:block;
	}
	.header{
		width:80%;
	}
}

.navbar{
	padding:0px!important;
}
.navbar-toggler-icon{
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='50' height='50' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2891, 98, 102, 1%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")!important;
	width:50px!important;
	height:50px!important;
}
.navbar-toggler{
	border-color: var(--primary-font-color)!important;
	border-radius:0px!important;
	border-width: 2px!important;
}
.navbar-toggle .icon-bar{
  width: 50px !important;
  height:3px !important;
}


.nav {
	width:100%;
	background-color: var(--primary-bg);
}

.nav-container{
	width:90%;
	margin:auto;
	max-width:1200px;
	display:flex;
	flex-wrap: wrap;
	justify-content: flex-start;
}

.nav-item{
	padding-left:15px;
	padding-right:15px;
	color: var(--nav-font-color);
	line-height:70px;
	transition: 0.1s;
	font-family: var(--main-font);
}
.nav-item:hover{
	background-color:var(--secondary-bg);
	color: var(--nav-font-color);
	text-decoration:none;
}

@media only screen and (max-width: 900px) {
	.nav-item {
	  font-size:14px;
	}
}

@media only screen and (max-width: 800px) {
  .nav-item {
	  font-size:12px;
  }
}

@media only screen and (max-width: 800px) {
	.nav-item {
	  font-size:12px;
	}
}

@media only screen and (max-width: 768px) {
	.navbar{
		padding:15px!important;
		
	}
	.nav-container{
		justify-content:flex-end!important;
	}
	.nav-item {
		font-size:16px;
		line-height:60px;
	}
	.navbar-nav {
		padding-top:15px!important;
	}
}

/************************************
		Main Content
*************************************/

.home-banner{
	width:100%;
	height:500px;
	background-image:url('../images/index/1n.png');
	background-size:cover;
	background-repeat: no-repeat;
}

.content-container {
	width:90%;
	margin:auto;
	max-width:1400px;
	padding-top:50px;
	padding-bottom:50px;
}
.content-containernopad {
	width:90%;
	margin:auto;
	max-width:1400px;
	/*padding-top:50px;*/
	padding-bottom:50px;
}
.contentgrey-text{
	width:100%;
	margin:auto;
	background-color: #ededed;
	/*max-width:1000px;*/
	margin-top:-10px;
	margin-bottom:50px;
}
.content-text{
	width:90%;
	margin:auto;
	max-width:1000px;
	margin-top:00px;
	margin-bottom:50px;
}
.content-text h1{
	text-align: center;
	color:var(--primary-bg);
	font-weight: bold;
	font-size: 55px;
	margin-bottom: 35px;
}

.supplier-logo-carousel {
	width:100%;
	margin:auto;
	max-width:1200px;
	margin-top:100px;
	margin-bottom:50px;
}

.TCbullet {
	margin-left: 20px;
}
/************************************
			Products
*************************************/


	.ProdsImg {
		height:60%;
		width:60%;
		padding: 5px;
		margin-bottom:10px;
	}
	
	.ProdGal {
		margin-left:auto;
		margin-right:auto;
		display: block;
		width:90%;
		min-height:700px;
		/*width:18%;*/
		text-align: center;
		padding-bottom:20px;
		color: #666;
		/*font-weight: 500;*/
		font-size: 16px;
		
	}
	
	.ProdItem {
		float: left;
		display:inline-block;
		width:18.6%;
		margin:0.5%;
		/*width:18%;*/
		text-align: center;
		border:1px solid #ecec;
		min-height:250px;
		padding-top:10px;
	}
	
	.GYSOverItem {
		float: left;
		display:inline-block;
		text-align: center;
		cursor: pointer;
		position: relative;
		/*border: 1px solid #ccc;*/
		margin:2%;
	}
	
	.GYSItemConf {
		width: 230px;
		height: 230px;
		background-size: cover;
		background-position: center;
		background-image: url("../images/products/confectionery_sweets.jpg");
	}
	
	.GYSItemDrinks {
		width: 230px;
		height: 230px;
		background-size: cover;
		background-position: center;
		background-image: url("../images/products/drinks.jpg");
	}
	
	.GYSItemCrisps {
		width: 230px;
		height: 230px;
		background-size: cover;
		background-position: center;
		background-image: url("../images/products/crisps.jpg");
	}
	
	.GYSItemDefault {
		width: 230px;
		height: 230px;
		background-size: cover;
		background-position: center;
		background-image: url("../images/products/logocat.png");
	}
	
	.GYSTitle {
		background-color:#B4CD34;
		color: fff;
		font-size:22px;
		text-decoration: none;
	}
	
	.GYSButton {
		background: #b4cd34;
		border-radius: 2px;
		width: 120px;
		height: 30px;
		font-size: 12px;
		color: #FFFFFF;
		letter-spacing: 1px;
		font-weight: 700;
		border:0px;
	}
	
	.GYSButton a {
		color: #FFFFFF;
	}
	
	.CatItem {
		float: left;
		display:inline-block;
		width:48%;
		margin:0.5%;
		/*width:18%;*/
		text-align: center;
		cursor: pointer;
		/*border:1px solid #666;
		border: 2px solid #a9c8ea;*/
		min-height:160px;
		position: relative;
	}
	
	.CatItem a {
		text-decoration: none;
	}

	.CatTitle {
		color:#B4CD34;
		font-size:22px;
		text-decoration: none;
	}

	.ProdNav1{
		display:block;
		margin-left:auto;
		margin-right:auto;
		padding-top: 20px;
		overflow:hidden;
		width: 96%;
		color: #666;
		font-size: 24px;
	}

	.ProdNav1 a {
		color: #666;
		font-style: underline;
	}
	
@media only screen and (max-width: 1280px) {
	
	.ProdItem {
		width:31%;
		min-height:260px;
	}
	
	.ProdsImg {
		height:75%;
		width:75%;
	}
	
	.ProdGal {
		min-height:1000px;
	}
	
	.CatItem {
		width:48%;
	}
	
	.CatItem img {
		height: 80%;
		width: 80%;
	}
	
}

@media only screen and (max-width: 700px) {
	
	.GYSItemConf {
		width: 200px;
		height: 200px;
	}
	
	.GYSItemDrinks {
		width: 200px;
		height: 200px;
	}
	
	.GYSItemCrisps {
		width: 200px;
		height: 200px;
	}
	
	.GYSItemDefault {
		width: 200px;
		height: 200px;
	}

}
@media only screen and (max-width: 600px) {
	.ProdItem {
		width:44%;
		min-height:280px;
	}
	.ProdsImg {
		height:90%;
		width:90%;
	}
	.ProdGal {
		min-height:1000px;
		width:70%;
	}
	.GYSOverItem {
		display:block;
		text-align: center;
		cursor: pointer;
		/*border: 1px solid #ccc;*/
		margin:2%;
	}
}

/************************************
			Footer
*************************************/

.footer {
	width:100%;
	padding-top:45px;
	padding-bottom:45px;
	background-color:var(--footer-bg);
	color:var(--primary-font-color);
	
}

.footer-content{
	width:98%;
	margin:auto;
	max-width:1400px;
	display:flex;
	justify-content:flex-start;
	align-items:flex-start;
	
}

.footer-content div{

}

.footer h4 {
	margin-left:-1px;
	margin-bottom:10px;
	font-size:21px;
	color: #666;
}

.footer a {
	display:block;
	margin-bottom:1px;
	font-size:16px;
	color: var(--footer-font-color);
}

.footer p {
	display:block;
	margin-bottom:1px;
	font-size:16px;
	color: var(--footer-font-color);
		
}

.sub-footer {
	width:100%;
	padding-top:15px;
	padding-bottom:15px;
	background-color:var(--primary-bg);
	color:#fff;
	overflow: hidden;
	
}

.sub-footer-content{
	width:90%;
	margin:auto;
	max-width:1400px;
	text-align:center;
	
}
.sub-footer p {
	line-height:50px;
	height:50px;
	margin-bottom:0px;
}

.footer-header {
	background-color:#f6f6f6;
}

.newsletter-signup {
	background-color:#5B6266;
	text-align: center;
	color: white;
}

.newsletter-email {
	width: 300px;
	padding: 7px;
}

.newsletter-submit {
	padding: 7px;
	border: none;
	background-color:var(--primary-bg);
}

.ImgLinksFooter {
	height: 30%;
	width: 30%;
	margin: 1%;
}


@media only screen and (max-width: 768px) {
	.sub-footer p{
		font-size:14px!important;
	}
	.newsletter-email {
		width: 250px;
	}
	
	.header-top-banner{
		font-size:9px;
	}
	
	.ImgLinksFooter {
		height: 70%;
		width: 70%;
		margin: 1%;
	}
}


/************************************
			ad rotator
*************************************/

.adslideshow-container {
width:90%;
    max-width:700px;
  position: relative;
  margin: auto;
  height:auto;
    display:block;
}

/************************************
		Main Content
*************************************/
.MText{
	margin-top: 10px;
	margin-left: 1.5%;
	display: flex;
	width: 97%;
	justify-content: space-between;
	background-color: #f1f1f1;
	
	/*border: 1px solid red;*/
}

.MText2{
	margin-top: 10px;
	margin-left: 1.5%;
	display: flex;
	width: 97%;
	justify-content: space-between;

	/*border: 1px solid red;*/
}


.indexbuttons{
	margin-top: 5px;
	margin-bottom: 5px;
	margin-right: 10px;
	width: 25%;	
	/*border: 1px solid green;*/
}

.butIndexa {
	width: 100%;
	min-height:120px;
	background-color: #f8f9fa;
	/*border: 3px solid #b4cd34;*/
	margin-bottom: 2px;
	/*text-align: center;*/
	font-size: 24px;
	color: white;
	cursor: pointer;
	text-align:center;
	top: 50%;
}
.butIndexa p {
	padding-top: 30px;
}
.butIndexa img {
	height: 22%;
	width: 22%;
	padding-right: 20px;
}
.butIndexa table {
	margin-left: 30px;
}
#butIndex1 {
	background-color: #dc4650;
}
#butIndex2 {
	background-color: #83c16a;
}
#butIndex3 {
	background-color: #ea8e4b;
}
#butIndex4 {
	background-color: #76c5e3;
}
#butIndex1:hover {
	background-color: #f36279;
}
#butIndex2:hover {
	background-color: #bbe094;
}
#butIndex3:hover {
	background-color: #ff9e6d;
}
#butIndex4:hover {
	background-color: #8dc7e9;
}

.butIndexMoba {
	display: none;
}

.Centerimg{
	width: 100%;
	margin-left: 10px;
	margin-right: 10px;
	margin-top: 10px;
	margin-bottom: 10px;
	align-content: center;
	height: auto;
	overflow: auto;
}


.Centerimg2{
	width: 100%;
	margin-left: 10px;
	margin-right: 10px;
	margin-top: 20px;
	margin-bottom: 10px;
	align-content: center;
	height: auto;
	overflow: auto;
}
.Centerimg3{
	width: 100%;
	margin-left: 10px;
	margin-right: 10px;
	margin-top: 10px;
	margin-bottom: 10px;
	align-content: center;
	height: auto;
	overflow: auto;
}

/* index logos */

.logoContainer {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr;
	gap: 10px;
	width: 100%;
	margin-top: 10px;
}
	
.logoContainer .logo {
	height: 100px;
	border: 2px solid #b4cd34;
	display: flex;
	justify-content: center;
	background-color: #fff;
}

.logoContainer .logo img { 
	display: block;
	margin: auto;
	max-height: 100%;
	max-width: 100%;
}

@media only screen and (max-width: 1799px) { .butIndexa { font-size: 20px; } }

@media only screen and (max-width: 1000px) {

	.indexbuttons{
		display: none;
	}

	.butIndexa {
		display:none;
	}

	.butIndexMoba {
		width: 75%;
		display: block;
		min-height:50px;
		background-color: #f8f9fa;
		/*border: 3px solid #b4cd34;*/
		padding-top:10px;
		margin-bottom: 10px;
		font-size: 20px;
		text-align: center;
		color: white;
		cursor: pointer;
	}
	.butIndexIcon {
		height: 28%;
		width: 28%;
	}

}

@media only screen and (max-width: 500px) {

	.butIndexMoba { width: 95%; }
	
	.ProdGal { width: 95%; }
}

@media only screen and (max-width: 390px) { #TelNoHead { display: none; } }

/************************************
			Other Features
*************************************/
#back-to-top {
    display: none;
    position: fixed;
    bottom: 85px;
    right: 5px;
    z-index: 99;
    border: none;
    outline: none;
    background-color: #b4cd34;
    color: white;
    cursor: pointer;
    padding: 15px;
    border-radius: 10px;
    font-size: 18px;
    box-shadow: 0px 4px 4px 0px rgba(0,0,0,0.4);
    transition: 0.2s linear;
}

ul.breadcrumb {
  padding: 25px 50px;
  list-style: none;
  background-color: var(--footer-bg);
  border-radius:0px!important;
  margin-bottom:0px!important;
}

ul.breadcrumb li {
  display: inline;
  font-size: 18px;
}

ul.breadcrumb li+li:before {
  padding: 8px;
  color: black;
  content: "/\00a0";
}

ul.breadcrumb li a {
  color: #0275d8;
  text-decoration: none;
}

ul.breadcrumb li a:hover {
  color: #01447e;
  text-decoration: underline;
} 

.btn-primary {
	background-color: var(--primary-bg);
	outline: none;
	border: 0px;
	border-radius: 0px;
}

.btn-primary:hover {
	background-color: var(--secondary-bg);
}

.contact-form-container {
	border-top: 3px solid var(--primary-bg);
}

.phone-app{
	width:220px!important;
	margin-left:auto!important;
	margin-right:auto!important;
	display:block;
}

.OLButMain {
	margin-left:auto;
	margin-right:auto;
	display: block;
	width:90%;
	min-height:150px;
	/*width:18%;*/
	text-align: center;
}

.OLLogin {
	width: 30%;
	height: 75px;
	background-color: #f8f9fa;
	border: 3px solid #b4cd34;
	font-size: 20px;
	color: #5b6266;
	text-align: center;
	margin-top:10px;
	margin-bottom:10px;
	padding-top: 20px;
	display:inline-block;
}

.OLLogin:hover {
	border: 3px solid #d2e185;
}

@media only screen and (max-width: 1280px) {

	.OLLogin {	
		width: 48%;
	}
	
}

@media only screen and (max-width: 750px) {
	.OLLogin {	
		width: 70%;
	}
}

@media only screen and (max-width: 500px) {
	.OLLogin {	
		width: 93%;
	}
}

