@import url(http://fonts.googleapis.com/css?family=Open+Sans:300,400,700);

/***** resets ******/

* {
	box-sizing: border-box;
}

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin:0;
    padding:0;
    border:0;
    outline:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}

body {
    line-height:1;
}

article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section { 
	display:block;
}

nav ul {
    list-style:none;
}

blockquote, q {
    quotes:none;
}

blockquote:before, blockquote:after,
q:before, q:after {
    content:'';
    content:none;
}

a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}

del {
    text-decoration: line-through;
}

abbr[title], dfn[title] {
    border-bottom:1px dotted;
    cursor:help;
}

table {
    border-collapse:collapse;
    border-spacing:0;
}

/* change border color to suit your needs */
hr {
    display:block;
    height:1px;
    border:0;   
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}

input, select {
    vertical-align:middle;
}

input[type="text"],
input[type="button"],
input[type="submit"],
input[type="tel"],
input[type="email"] {
	-webkit-appearance: none;
	-moz-appearance: none;
	-webkit-border-radius:0; 
	border-radius:0;
}

/** general **/

::-moz-selection { background: #E8C900; color: white; }
::selection { background: #E8C900; color: white; }

body {
	font-family: 'Open Sans', sans-serif;
	background: #f7f7f7;
	font-size: 16px;
	color: #333;
}

input, textarea {
	font-family: 'Open Sans', sans-serif;
	font-size: 14px;
}

a, p {
	line-height: 1.3;
}
a {
	color: #e8c900;
}

h1 {
	font-size: 40px;
}

h2 {
	font-weight: 300;
	color: #444;
	margin:0 auto 15px auto;
	text-align: center;
	padding: 20px;
	font-size: 35px;
}

h3 {
	font-size: 22px;
	margin: 10px auto;
	font-weight: 500;
}
h4 {
	font-size: 20px;
	margin: 10px auto;
	font-weight: 300;
}
ul, ol {
	padding: 10px 0px 10px 35px;
	margin: 10px 0;
}
ol.index {
	padding: 10px 35px;
	margin: 10px 0;
	border-bottom: 2px dashed #e3e3e3;
	border-top: 2px dashed #e3e3e3;
	background: white;
}
li {
	padding: 3px 0;
	line-height: 1.4;
}
li > p {
	padding-left: 25px;
}

input[type="text"],
input[type="tel"],
input[type="email"],
textarea {
	border: 1px solid #ccc;
	padding: 4px;
}

.container {
	max-width: 1000px;
	margin: 0 auto;
}

.button {
	background-color: white;
	border: 1px solid #ccc;
	padding: 5px 10px;
	cursor: pointer;
	font-size: 16px;
}

.button:hover {
	background: #ffff54;
}

.button:active {
	background: #e8c900;
	border: 1px solid #e8c900;
}

.center {
	text-align: center;
	width: 100%;
}
/** header **/

header {
	background-color: white;
	border-bottom: 1px solid #f3f3f3;
}

#logo {
	width: 100%;
	text-align: center;
	padding-top: 5px;
}

#logo img {
	width: auto;
	max-width: 100%;
}

#menuIcon {
	display: none;
	width: 20%;
	vertical-align: middle;
	text-align: center;	
	color: #e8c900;
}
#menuIcon.active {
	background: #f7f7f7;
}
#menuIcon::after {
	content: 'MENU';
	font-size: 12px;
	line-height: 12px;
}
.three-bar {
	margin: 0 auto;
	display: block;
	width: 30px;
	height:30px;
	line-height:30px;
}
.three-bar .bar{
	display: block;
	width: 30px;
	height: 10px;
	text-align: center;
	border-bottom: 5px solid;
}

/** MENU **/

nav {
	text-align: center;
	padding-top: 5px;
	background: white;
}
.menu {
	padding: 0;
	margin: 0;
}

.menu a {
	text-decoration: none;
	padding: 10px 15px;
	display: block;
	color: #000136;
}

.menu li {
	display: inline-block;
	margin-left: -4px;
	position: relative;
	cursor: pointer;
	width: 185px;
	box-sizing: border-box;
	padding: 0;
	margin: 0;
}

.menu li.active {
	
}
.menu li.active > a[href] {
	border-bottom: 5px solid #f9e500;
}
.menu li.active > a:not([href]) {
	margin-bottom: 5px;
}

.menu > li.active > a {
	padding-bottom: 5px;
}

.menu li ul {
	display: none;
	background: white;
	margin: 0;
	padding: 0;
}
.menu li ul li {
	display: block;
	text-align: left;
	font-size: 14px;
	margin-left: 0;
	border-left: 5px solid #f9e500;
}

.menu li ul li.hover {
	background: #ffff54;
	border-left: 5px solid #ffff54;
}

.menu li.active ul {
	display: block;
	position: absolute;
	z-index: 1;
}

/** content **/

#content > section:nth-child(even) {
	background-color: white;
}

.full {
	padding: 25px 15px 50px 15px;
}

.full p {
	text-indent: 25px;
	line-height: 1.5;
}

.full h1 {
	font-weight: 300;
	color: #444;
	margin:0 auto 15px auto;
	text-align: center;
	border-bottom: 2px dashed #e3e3e3;
	padding-bottom: 20px;
}

.half {
	width: 51%;
	display: inline-block;
	padding: 0 2% 0 2%;
	vertical-align: top;
}

.half:nth-child(odd) {
	width: 49%;
	padding: 0 2% 0 0;
	margin-left: -4px;
}
.half.image-grid {
	margin-bottom: 20px;
}

.half .sq-img-container {
	width: 100%;
	height: 300px;
	background-position: 50% 50%;
	background-size: cover;
	background-repeat: no-repeat;
}

.manufacturers {
	padding: 50px 0;
	text-align: center;
}

.manufacturers > div{
	display: inline-block;
	padding: 0 5px;
	text-align: center;
	vertical-align: middle;
}
.manufacturers > div > img {
	max-width: 100%;
	height: auto;
}


.manufacturers > div > img[alt="Graber"] {
	background-color: #381f1e;
	padding: 20px 5px;
}
.manufacturers > div > img[alt="Levolor"] {
	background-color: #305683;
	padding: 15px 5px;
}

.c2 {
	width: 48%;
}
.c3 {
	width: 32%;
}
.c6 {
	width: 16%;
}
.c7 {
	width: 13.5%;
}

.red {
	color: #ff7777;
}
.yellow {
	color: #E4DD02;
}
.banner {
	height: 600px;
	background-size: cover;
	background-position: center center;
	position: relative;
}
.banner.sub {
	height: 300px;
}
.banner .overlay {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background: rgba(0,0,0,0.2);
}
.banner .wrap {
	color: white;
	text-shadow: 1px 1px 5px rgba(0,0,0,0.6);
	position: absolute;
	bottom: 75px;
	left: 75px;
	width: 50%;
}
.banner.sub .wrap {
	width: auto;
	top: 50%;
	left: 0;
	right: 0;
	bottom: auto;
	text-align: center;
	margin-top: -40px;
}
.banner h1 {
	font-size: 38px;
}
.banner.sub h1 {
	font-size: 90px;
	text-transform: uppercase;
	opacity: .7;
	line-height: .8;
}

.banner p {
	font-size: 20px;
	margin-top: 10px;
}

.action-button {
	margin-top: 10px;
	width: 250px;
	height: 50px;
	color: white;
	text-shadow: 1px 1px 5px rgba(0,0,0,0.3);
	box-shadow: 1px 1px 5px 0px rgba(0,0,0,0.3);
	background-color: #e8c900;
	font-size: 20px;
	position: relative;
	border: 0;
}
.no-touchevents .action-button:hover {
	top: -3px;
	background: #ddbc02;
}
.action-button:focus {
	outline: none;
}
.action-button:active {
	top: 0;
	background: #d6b200;
	box-shadow: inset 0 0 8px 1px rgba(0,0,0,0.3);
}

.contact-form {
	width: 600px;
	margin: 20px auto 0 auto;
}
.contact-form p {
	text-indent: 0;
}
.contact-form > div {
	padding-bottom: 15px;
}

.contact-form > div > label {
	display: block;
	width: 200px;
	padding: 5px 0;
	font-size: 18px;
}

.contact-form .text-input {
	width: 100%;
}
.contact-form .bad {
	border: 1px solid #ff7777;
}
.contact-form .warn {
	border: 1px solid #ffef77;
}
.contact-form .button {
	padding: 10px 25px;

}

.contact-form .radios > div {
	padding: 10px 0;
}
.contact-form .radios > div > input {
	margin: 0 3px 0 0;
}
.contact-form .radios > div > label {
	padding-right: 35px;
}
.contact-form .radios > div > label:last-child {
	padding-right: 0;
}

.error p {
	color: #ff7777;
}

.overlay {
	display: none;
	position: absolute;
	top:0;
	right: 0;
	bottom:0;
	left: 0;
}

.message-box {
	display: none;
	width: 500px;
	margin: 0;
	padding: 25px;
	background: white;
	box-shadow: 1px 1px 5px 0px rgba(0,0,0,0.2);
	min-height: 100px;
	text-align: center;
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.message-box p {
	text-indent: 0;
	font-size: 14px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.message-box .close {
    position: absolute;
    right: 5px;
    top: 5px;
    width: 25px;
    height: 25px;
    text-align: center;
    font-size: 20px;
    cursor: pointer;
}



/** footer **/

footer {
	background-color: #4f4f4f;
	color: #eee;
	padding: 25px;
	text-align: center;
}

footer .container {
	display: table;
	width: 100%;
}

footer section {
	display: table-cell;
	vertical-align: top;
	width: 33%;
	padding-left: 25px;
}
footer section:first-child {
	padding-left: 0;
}

footer .block {
	margin-bottom: 7px;
}

footer .block a {
	padding-left: 5px;
}

footer h3 {
	margin-top: 0;
}

.scroll-to-top {
	display: none;
	width: 80px;
	height: 80px;
	background: url(http://www.saundersinteriors.com/media/img/arrow_up.png);
	background-size: contain;
	background-repeat: no-repeat;
	position: fixed;
	bottom: 0;
	left: 0;
	cursor: pointer;
	margin-left: 10px;
	margin-bottom: 10px;
}

/**** 404/403/500 errors *****/

.server-error {
	width: 25%;
	margin: 200px auto;
	text-align: center;
	border: 2px dashed #e3e3e3;
	padding: 25px;
	min-width: 200px;
}
.server-error h1 {
	font-weight: bold;
	color: rgba(0,0,0,0.075);
	padding-bottom: 10px;
	font-size: 60px;
}

/***** MOBILE ******/

@media screen and (max-width: 950px) {
	.menu li {
		width: auto;
	}

	.menu li ul li {
		width: 160px;
	}
	.manufacturers {
		padding: 35px 0;
	}
}

@media screen and (max-width: 650px) {
	.menu > li > a{
		padding: 10px 10px
	}
	.manufacturers {
		padding: 35px 0 15px 0;
	}
	.manufacturers > div {
		padding-bottom: 20px;
	}
	.c6 {
		width: 30%;
	}
	.c7 {
		width: 24%;
	}
	.banner.sub .wrap {
		margin-top: -34px;
	}
	.banner.sub h1 {
		font-size: 85px;
	}
	.server-error {
		margin: 150px auto;
	}
	.full {
		padding-left: 10px;
		padding-right: 10px;
	}
	.half.mobile-fold {
		width: 100%;
		padding-left: 0;
		padding-right: 0;
	}
	.mobile-fold h4 {
		text-align: left;
	}

	.contact-form {
		width: 100%;
	}
	.button-line {
		text-align: center;
	}
}

@media screen and (max-width: 600px) {
	#menuIcon {
		display: table-cell;
	}
	#logo {
		display: table-cell;
		vertical-align: middle;
		width: 80%;
	}
	nav {
		display: none;
		border-top: 1px solid #f3f3f3;
		background: #f7f7f7;
	}
	.menu li {
		width: 100%;
		text-align: left;
		border-bottom: 1px solid #f1f1f1;
		margin-left: 0;;
	}
	.menu > li > a:not([href])::after {
		content: '\25B8';
		padding-left: 5px;
		opacity: .7;
	}
	.menu > li.active > a:not([href])::after {
		content: '\25BE';
	}
	.menu li:last-child,
	.menu li.active {
		border-bottom: none;
	}
	.menu li ul li {
		border-bottom: 1px solid #ededed;
	}
	.menu li ul li > a:active {
		background: #f9f9f9;
	}

	.menu li.active ul {
		position: static;
		width: 100%;
	}

	.menu li.active ul > li {
		width: auto;
	}

	.banner {
		height: 500px;
	}
	.banner h2 {
		font-size: 32px;
	}
	.banner.sub h1 {
		font-size: 65px;
	}
	footer .container {
		display: block;
	}
	footer section {
		display: inline-block;
		width: 45%;
	}
	.half .sq-img-container {
		height: 250px;
	}

	.message-box {
		width: 90%;
		padding: 15px 10px;
		margin-left: 5%;
		left: 0;
		min-height: 0;
		transform: translate(0, -50%);
	}
	.message-box p {
		position: static;
		transform: none;
	}

}

@media screen and (max-width: 480px) {
	.banner .wrap {
		bottom: 50px;
		left: 50px;
	}
	footer section {
		display: block;
		width: 100%;
		padding-left: 0;
		margin-bottom: 15px;
	}
	.banner.sub {
		height: 250px;
	}
	.banner.sub h1 {
		font-size: 55px;
	}
	.server-error {
		margin: 100px auto;
	}
}

@media screen and (max-width: 350px) {
	#menuIcon::after {
		content: '';
	}
	.banner .wrap {
		bottom: auto;
		left: 30px;
		top: 50%;
		margin-top: -25%;
		right: 30px;
		width: auto;
	}
	.banner.sub {
		height: 210px;
	}
	.banner.sub .wrap {
		margin-top: -26px;
	}
	.banner.sub h1 {
		font-size: 45px;
	}
	.server-error {
		margin: 100px auto;
	}
}