body {
  font-family: Arial;
  font-size: 17px;
  padding: 8px;
	background-color:#F7F7F7;
}

* {
  box-sizing: border-box;
}

.row {
  display: -ms-flexbox; /* IE10 */
  display: flex;
  -ms-flex-wrap: wrap; /* IE10 */
  flex-wrap: wrap;
  margin: 0 -16px;
}

.col-25 {
  -ms-flex: 25%; /* IE10 */
  flex: 25%;
}

.col-50 {
  -ms-flex: 50%; /* IE10 */
  flex: 50%;
}

.col-75 {
  -ms-flex: 75%; /* IE10 */
  flex: 75%;
}

.col-25,
.col-50,
.col-75 {
  padding: 0 16px;
}

.container {
  background-color: #FFF;
  padding: 5px 10px 15px 10px;
  border: 1px solid lightgrey;
  border-radius: 3px;
}

input[type=text],input[type=tel],input[type=email] {
  width: 100%;
  margin-bottom: 20px;
  padding: 12px;
  border: 1px solid #ccc;
  border-radius: 3px;
}

label {
  margin-bottom: 10px;
  display: block;
}

.icon-container {
  margin-bottom: 20px;
  padding: 7px 0;
  font-size: 24px;
}

.btn {
  background-color: #4CAF50;
  color: white;
  padding: 16px;
  margin: 10px 0;
  border: none;
  width: 100%;
  border-radius: 3px;
  cursor: pointer;
  font-size: 22px;
}

.btn:hover {
  background-color: #45a049;
}

a {
  color: #2196F3;
}

hr {
  border: 1px solid lightgrey;
}

span.price {
  float: right;
  color: grey;
}
	
.cart_check {
	width:20px;
	height:20px;
}

h3 {
	font-weight: bold;	
}
	
/* Responsive layout - when the screen is less than 800px wide, make the two columns stack on top of each other instead of next to each other (also change the direction - make the "cart" column go on top) */
@media (max-width: 800px) {
  .row {
    flex-direction: column-reverse;
  }
  .col-25 {
    margin-bottom: 20px;
  }
}
	
.divider {
	display:block;
	height:1px;
	border-top:1px solid #CCC;
	margin:10px auto 10px auto;
}
	
.req_error {
	border:2px solid red;	
}
	
#error_container {
	display: block;
	padding: 20px;
	background-color: #f44336; /* Red */
	color: white;
	margin-bottom: 15px;
	text-align: center;
}	
	
.col-251 {  padding: 0 16px;
}
.col-751 {  padding: 0 16px;
}
	
.select-css {
	display: block;
	font-size: 16px;
	font-family: sans-serif;
	font-weight: 700;
	color: #444;
	line-height: 1.3;
	padding: .6em 1.4em .5em .8em;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	margin: 0;
	border: 1px solid #aaa;
	box-shadow: 0 1px 0 1px rgba(0,0,0,.04);
	border-radius: .5em;
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
	background-color: #EBEBEB;
	background-repeat: no-repeat, repeat;
	background-position: right .7em top 50%, 0 0;
	background-size: .65em auto, 100%;
}
.select-css::-ms-expand {
	display: none;
}
.select-css:hover {
	border-color: #888;
}
.select-css:focus {
	border-color: #aaa;
	box-shadow: 0 0 1px 3px rgba(59, 153, 252, .7);
	box-shadow: 0 0 0 3px -moz-mac-focusring;
	color: #222;
	outline: none;
}
.select-css option {
	font-weight:normal;
}	
	
.gray_button {
	display: block;
	font-size: 16px;
	font-family: sans-serif;
	font-weight: 700;
	color: #444;
	line-height: 1.3;
	padding: .6em 1.4em .5em .8em;
	width: auto;
	max-width: 100%;
	box-sizing: border-box;
	margin: 0;
	border: 1px solid #aaa;
	box-shadow: 0 1px 0 1px rgba(0,0,0,.04);
	border-radius: .5em;
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
	background-color: #fff;
	background-repeat: no-repeat, repeat;
	background-position: right .7em top 50%, 0 0;
	background-size: .65em auto, 100%;
}

#overlay {
  position: fixed; /* Sit on top of the page content */
  display: none; /* Hidden by default */
  width: 100%; /* Full width (cover the whole page) */
  height: 100%; /* Full height (cover the whole page) */
  top: 0px;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(255,255,255,0.5); /* Black background with opacity */
  z-index: 2000; /* Specify a stack order in case you're using a different order for other elements */
  cursor: pointer; /* Add a pointer on hover */
}		
		
#overlay_int {
  position: fixed; /* Sit on top of the page content */
  display: none; /* Hidden by default */
  width: 100%; /* Full width (cover the whole page) */
  height: 100%; /* Full height (cover the whole page) */
  top: 0px;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(255,255,255,0.8); /* Black background with opacity */
  z-index: 2010; /* Specify a stack order in case you're using a different order for other elements */
  cursor: pointer; /* Add a pointer on hover */
}	

#text{
  position: absolute;
  top: 50%;
  left: 50%;
  font-size: 30px;
  color: #333;
  transform: translate(-50%,-50%);
  -ms-transform: translate(-50%,-50%);
  opacity: 0.7;	
}		

.select {
	padding:10px;
	background-color:#F4F4F4;
	border-radius:4px;
	font-size:15px;
}
	
.apply_promo {
	padding:10px;
	font-size:13px;
}

textarea:focus, input:focus{
    outline: none;
}	
	
#footer_social a {
	font-size: 22px;
	line-height: 40px;
	margin:0px 10px 0px 10px;
}
	
#footer_other a {
	font-size: 14px;
	display: inline;
	line-height: 40px;
	margin: 0px 20px 0px 20px;
	color:#333;
	text-decoration: none;
}
	
.tabs{
    width:auto;
    height:auto;
    margin:0 auto;
}

/* tab list item */
.tabs .tabs-list{
    list-style:none;
    margin:0px;
    padding:0px;
}
.tabs .tabs-list li{
    width:100px;
    float:left;
    margin:0px;
    margin-right:2px;
    padding:10px 5px;
    text-align: center;
    background-color:transparent;
    border-radius:0px;
}
.tabs .tabs-list li:hover{
    cursor:pointer;
}
.tabs .tabs-list li a{
    text-decoration: none;
    color:#333;
}

/* Tab content section */
.tabs .tab{
    display:none;
    width:96%;
    min-height:250px;
    height:auto;
    border-radius:0px;
    padding:20px 15px;
    background-color:#EBEBEB;
    color:darkslategray;
    clear:both;
}
.tabs .tab h3{
    border-bottom:3px solid #CCCCCC;
    letter-spacing:1px;
    font-weight:normal;
    padding:5px;
}
.tabs .tab p {
    line-height:20px;
    letter-spacing: 1px;
}

/* When active state */
.active{
    display:block !important;
}
.tabs .tabs-list li.active{
    background-color:#EBEBEB !important;
    color:black !important;
}
.active a{
    color:black !important;
}

/* media query */
@media screen and (max-width:360px){
    .tabs{
        margin:0;
        width:96%;
    }
    .tabs .tabs-list li{
        width:80px;
    }
}
.add_to_cart {
	color: #000;
	display: block;
	position: relative;
	text-decoration: none;
	background-color: #ffcc66;
	font-size: 23px;
	padding: 15px;
	text-align: center;
	margin: 0px auto 0px auto;
	width: 100%;
	max-width: 350px;
	border:1px solid transparent;
}
.add_to_cart:hover {
	border:1px solid #333;	
}
.image_container {
	float: left; margin: 0px 5px 0px 0px;
	width:50px;
	height:50px;
	overflow: hidden;
}
	
.tag {
    display: inline-block;
    margin: 8px 10px 2px 0px;
    padding:4px;
    background-color:#CCC;
    color:#000;
    position: relative;
    padding-right: 10px;
    padding-left: 10px;
    border-radius: 10px;
	text-decoration: none;
    font-size: 13px;
}	
	
/* Track */
::-webkit-scrollbar-track {
  background: #f1f1f1; 
}
 
/* Handle */
::-webkit-scrollbar-thumb {
  background: #888; 
}

/* Handle on hover */
::-webkit-scrollbar-thumb:hover {
  background: #555; 
}	
	
p {
	padding:0px;
	margin:0px;
}
	
p span {
	display:inline;
	padding:0px;
	margin:0px;
} 

.col_right {
	display: block; 
	float: left; 
	width:520px;
	max-width: 550px; 
	margin-left:30px;	
}

.col_right_mobile {
	display:block;
	float:none;
	width:520px;
	margin:80px auto 0px auto;
}
	
.col_left {
	display: block; 
	float: left; 
	width:350px;	
}
	
.col_left_mobile {
	display:block;
	float:none;
	width:400px;
	margin:0px auto 0px auto;
}	
	
.search_field {
	display: block; 
	margin: 0px auto 0px auto; 
	padding:12px; 
	font-size: 17px; 
	border-radius:10px; 
	width:99%; 
	border:1px solid #CCC; 
	background-color: #FFF;
}
	
.search_container {
	display:inline; 
	width: 30%; 
	float: left;
}
	
.search_container_mobile {
	display:block;
	width:80%;
	max-width:600px;
	float:none;
	position:relative;
	padding-top:70px;
	margin:30px auto -20px auto;
}
	
.search_container_mobile_narrow {
	display:block;
	width:80%;
	max-width:600px;
	float:none;
	position:relative;
	padding-top:0px;
	margin:10px auto -20px auto;
}

.top_right {
	display: inline; 
	float:left; 
	width: 30%; 
	margin-top: 5px; 
	text-align: right;
}
	
.top_right_mobile {
	display: inline; 
	float:none;
	right:30px;
	top:45px;
	width: 400px; 
	margin-top: 5px; 
	text-align: right;
	position:absolute;
}	

.top_right_mobile_narrow {
	display: block; 
	float:none;
	width: 100%; 
	margin-top: 5px; 
	text-align: center;
	position:relative;
	margin:50px auto -15px auto;
}	

#header_container {
	width:100%; 
	max-width: 1200px; 
	display: block; 
	height: auto; 
	min-height: 50px; 
	margin:25px auto 20px auto;	
}

.logo {
	float:left; 
	width:30%; 
	display:block; 
	height:60px;
}

.logo_mobile_narrow {
	float:none; 
	position: relative;
	display:block; 
	height:60px;
	text-align: center;
}

.tab_container {
	display: block; 
	width:100%; 
	position: relative; 
	clear: both; 
	max-width: 1100px; 
	margin:0px auto 0px auto;	
}

.info_only {
	background-color:yellow;
	padding:15px;
	padding-left:70px;
	color:#333;
	font-size: 16px;
	display:block;
	position:relative;
	margin:10px auto 10px auto;
	line-height: 22px;
}
h2 {
	font-size: 18px;	
}