/*
      _           _    _
   __| | ___  ___| | _| |_ ___  _ __
  / _` |/ _ \/ __| |/ / __/ _ \| '_ \
 | (_| |  __/\__ \   <| || (_) | |_) |
  \__,_|\___||___/_|\_\\__\___/| .__/ 
                               |_|     

changes for desktop
*/

.container-fluid {
	width: 1163px;   /* this is to lock down the width on desktop, to what existed previously */
	margin: 0 auto;  /* this is to keep it centered */
}

.vertical-spacer {
	padding-bottom: 80px;
	min-height: 651px;
}

.nobr {
	white-space: nowrap;
}

/* undo bootstrap */
.ui-widget input[type=checkbox],
.ui-widget input[type=radio] {
  margin: 3px 0.5ex;
}

/* undo bootstrap */
a:hover, a:focus {
  color: #000;
  text-decoration: none;
}

#home-page button.positive {
    font-size: 80%;
    margin-left: 10px;
}

#school-search #state {
	width: calc(100% - 30px);
}

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

.school-ul li {
	margin-bottom: 10px;
}

.school-ul a {
	color: #89052C;
}

/* main nav */

.navbar-fixed-bottom,
.navbar-fixed-top {
	position: absolute;
}

.navbar-fixed-bottom .navbar-collapse,
.navbar-fixed-top .navbar-collapse {
	max-height: calc(100vh - 50px);
	width: 100%;
	background: white;
	position: absolute;
	top: 0;
	box-shadow: 0px 30px 40px 0 rgba(0,0,0,.5);
	z-index: 1101;
}

.navbar-brand {
	height: 70px;
	width: 78px;
	padding: 0;
	margin: 15px;
	overflow: hidden;
	display: inline-block;
}

.navbar-brand img {
	width: 78px;
}

.logo-container {
	text-align: center;
	margin: 0 auto 15px;
}

.navbar-default .navbar-toggle {
	border: 0;
}

.navbar-default .navbar-toggle .icon-bar {
	background-color: #89052C;
	width: 30px;
	height: 3px;
}
.navbar-toggle .icon-bar+.icon-bar {
	margin-top: 5px;
}


.navbar-toggle {
	margin-top: 30px;
}

.nav>li {
	border-bottom: 1px solid #C0C0C0;
}

.navbar-default .navbar-nav>li>a {
	color: #89062C;
	font-size: 18px;
	padding-top: 20px;
	padding-bottom: 20px;
}

li.cart,
.navbar-default .navbar-nav>li.cart a {
	text-transform: uppercase;
	font-size: 16px;
	color: #89062C;
}

li.cart img {
	margin-top: -3px;
}

.navbar-default .navbar-nav>li.cart a:hover {
	color: #89062C;
}

img.shopping-cart {
	width: 16px;
}

.new-nav-close {
	cursor: pointer;
	float: right;
	z-index: 100000;
	position: relative;
	display: block;
	padding: 19px;
}

img.menu-close {
	width: 16px;
}

/* small nav */

.navbar-default .navbar-right>li>a {
	font-size: 16px;
	padding-top: 15px;
	padding-bottom: 15px;
}

.nav.navbar-right>li {
	border-bottom: none;
}


/* div tables */

.d-table {
	display: table;
	width: 100%;
	border: 1px solid #C0C0C0;
}

.d-thead {
	display: table-header-group;
	font-weight: bold;
}

.d-tbody {
	display: table-row-group;
}

.d-tr {
	display: table-row;
}

.d-td {
	display: table-cell;
	padding: 5px 10px;
	vertical-align: top;
	/* box-sizing: content-box; */
}

.cart-image {
	width: 14.0583554%; /* 106 / 754 */
}
.cart-description {
	padding-top: 10px;
}
.cart-unit-price {
	padding-top: 10px;
}
.cart-quantity {
	text-align: center;
}
.cart-quantity input {
	float: none;
	margin: 0;
}
.d-tbody .cart-subtotal {
	padding-top: 10px;
	text-align: right;
}
#checkout-review .d-tbody .cart-quantity {
	padding-top: 10px;
}

.d-thead .cart-subtotal {
	text-align: right;
}
.cart-image .categoryImg {
	margin-right: 0;
}

/* checkout/review and order/display */
#totals {
	clear: both;
}

#checkout-review .promo_code {
	border-top: 0;
	margin-bottom:0;
}

#checkout-review .label_space {
	width: auto;
}

#checkout-review select#HowDidYouHearAboutFS {
	margin-bottom: 0;
}

#checkout-review .promo_code p {
	padding-top: 10px;
}

.cc_form {
	clear: both;
}

#order-display .shopping_cart {
	border-top: 0;
}

#checkout-shipping label.duplicate-label {
	float: none;
	width: 100%;
	text-align: left;
	margin-bottom: 15px;
}

#checkout-shipping #residential-address,
#checkout-shipping #commercial-address {
	text-align: left;
    clear: none;
    float: none;
    display: inline;
}

#checkout-shipping .shipping input {
	float: left;
	margin: 1px 6px 0 0;
}

/* forms */

/* buttons on user/account and user/login checkout/login  */
.formAccount2 button.positive,
.label_space + button {
	padding: 5px 10px;
	margin-left: 135px;
}
/* my account page AND user/login */
.my-account-profile select,
.my-account-profile select#addr_country, /* needs to be this specific */
.create-an-account select,
.create-an-account select#addr_country {
	width: 200px;
}

input#addr_state {
	width: 200px;
}

.buttons.multi-buttons {
	padding-left: 132px;
}

.buttons.multi-buttons button.positive,
.buttons.multi-buttons button.positiveL {
	display: inline-block;
	float: none;
	margin: 0 10px 0 0;
}

#stylized2 .label-reset {
	width: auto;
	float: none;
	text-align: left;
	margin: 0;
	padding: 5px 0;
}

/* user account */
#user-account .profile {
	width: 373px;
}

#user-account .profile + .profile {
	margin-right: 0;
}

#user-account .order_history {
	margin-top: 0;
	width: 100%;
	display: block;
}
#user-account .order_history td {
	width: 1%;
	white-space: nowrap;
}
#user-account .order_history th:first-of-type {
	white-space: nowrap;
}
#user-account .order_history td:last-of-type {
	text-align: center;
}

#profile-center .mailing .label_space {
	display: none;
}

#profile-center .mailing label {
	width: 100%;
	text-align: left;
	margin-left: 95px;
}

#profile-center .mailing input#mailingList {
	margin: 0 5px 0 0;
}


/* share modal */

#colorbox {
	box-sizing: content-box; /* undo bootstrap */
	z-index: 9999996 !important /* this is 2 layers higher than the colorpicker's "specktrum.css" property, had to bump up overlay's z-index as well to cover colorpicker box */
}

#cboxOverlay {
	z-index: 9999995 !important /* this is 1 layer higher than the colorpicker's "specktrum.css" property */
}

#colorbox .buttons {
	clear: none;
}

#colorbox .example8 {
	float: right;
}

#colorbox #stylized {
	width: 100%;
}

#colorbox label.share_email {
	display: block;
	text-align: left;	
}

#colorbox #stylized input,
#colorbox #stylized textarea {
	margin-left: 0;
	width: 100%;
	margin-bottom: 0;
}

#colorbox #stylized #shareEmailSendCopy {
	width: 15px;
	margin-left: 6px;
	margin-top: 6px;
}


/* content pages */

.content-table td {
	padding-top: 4px;
	padding-bottom: 4px;
}

.content-page #creator_pricing2 .size_label {
	float: none;
}

.content-page #terms-conditions {
	font-style: italic;
	font-size: 10px; 
	margin-top: 10px;
}

.content-page .rowElemAccount3 {
	margin-bottom: 10px;
}

.content-page #creator_pricing2 .positiveFrame2 {
	margin-right: 10px;
	margin-bottom: 10px;
}

/* billing shipping review (for CSR accounts) */

#billing-shipping-review .shipping_options .radio {
	display: inline-block;
}

#clearOrderContainer {
	margin: 10px 0 0 0;
	float: none;
}

#clearOrderContainer .formControls {
	width: auto;
	margin-right: 0;
}

#clearOrderContainer .formControls button {
	margin-right: 0;
	float: left;
}



/*
 _                    _                  _       _
| |__  _ __ ___  __ _| | __  _ __   ___ (_)_ __ | |_
| '_ \| '__/ _ \/ _` | |/ / | '_ \ / _ \| | '_ \| __|
| |_) | | |  __/ (_| |   <  | |_) | (_) | | | | | |_
|_.__/|_|  \___|\__,_|_|\_\ | .__/ \___/|_|_| |_|\__|
                            |_|

prevents desktop interferences
*/

@media (max-width: 767px) {

	/* genral elements */

	.buttons button[type] {
		font-size: 12px;
	}

	input[type="color"],
	input[type="date"],
	input[type="datetime"],
	input[type="datetime-local"],
	input[type="email"],
	input[type="month"],
	input[type="number"],
	input[type="password"],
	input[type="search"],
	input[type="tel"],
	input[type="text"],
	input[type="time"],
	input[type="url"],
	input[type="week"] {
		padding-left: 8px !important;
		padding-right: 8px !important;
	}

	/* mobile button size CTA */
	#school-search button,
	#creator_pricing .buttons button,
	#cart-display #continueShoppingForm button,
	#cart-display #checkoutForm button,
	#user-login .buttons button.positive,
	#user-account .buttons button,
	#checkout-login .buttons button.positive,
	#checkout-login .buttons button.positiveL,
	#checkout-billing .buttons button,
	#checkout-shipping .buttons button,
	#checkout-review .buttons button,
	#profile-center button.positiveR  {
		padding: 12px 14px;
		font-size: 12px;
	}

	/* alerts */

	.cbox_messagebox_error {
		width: auto;
		float: none;
	}	

	/* header */

	.container-fluid {
		width: auto;
		min-width: 360px;
	}

	#header {
		position: absolute;
		z-index: 1100;
		margin-left: 100px;
	}

	#header_logo {
		padding: 0;
		line-height: 17px;
	}

	#header_logo a {
		font-size: 14px;
		font-size: 14px;
		white-space: nowrap;
	}

	#header_logo span {
		display: block;
	}

	#header_phone {
		padding: 0;
		font-size: 10px;
		white-space: nowrap;
	}


	/* sidebar - sub nav */

	#sidebar {
		margin-top: 100px;
		width: auto;
		float: none;
		margin-left: 0; /* to undo bootstrap compensation from desktop view */
	}

	#section_nav {
		width: auto;
		background: transparent;
		padding-top: 15px;
	}

	#section_nav li,
	#section_nav li.active li {
		float: left;
		margin-bottom: 14px;
	}

	#section_nav.non-flow li,
	#section_nav.non-flow li.active li {
		margin-right: 10px;
		border-right: 1px solid #656565;
	}

	#section_nav.non-flow li:last-child {
		border-right: none;
	}

	#section_nav li a,
	#section_nav li.active li a {
		display: block;
		line-height: 16px;
		padding: 0 10px 0 0;
		margin: 0;
		width: auto;
		color: #656565;
		background: transparent;
		font-weight: normal;
		text-transform: none;
		height: auto;
		text-align: left;
		text-decoration: underline;
		font-size: 12px;
		border-bottom: none /* for breadcrumbs only */
	}

	#section_nav li a:hover {
		color: black;
		text-decoration: none;
	}

	#section_nav li.active a {
		background: transparent;
		color: #89062C;
		font-weight: bold;
		text-transform: none;
	}


	/* sidebar - breadcrumb nav */

	#section_nav li ul {
		/*
			this ul is inside of a floated li
			that floated li is only as wide as its conents
			the contents of THIS ul may or may not expand to occupy 100%, so width: 100%/auto won't work
			this forces this ul to occupy 100% of the viewport, minus 15px on each side for gutters
			thus allowing li to wrap properly both as breadcrumbs and subnav
		*/
		width: calc(100vw - 30px);
	}

	#section_nav li a.breadcrumb {
		float: left;
		font-weight: normal;
		position: relative;
		color: #656565;
		margin-bottom: 14px;
		border-radius: 0;
	}

	.with-flow li a:after {
		content: " >";
		padding-left: 10px;
		float: right;
	}

	.with-flow li.active li.active a:after,
	.with-flow li.active li:last-of-type a:after {
		content: " ";
	}

	#section_nav li.active li {
		position: relative;
	}

	#section_nav li.active li a {
		padding: 0 10px 0 0;
	}

	#section_nav li ul li.active:after {
		display: none; /* not working on firefox, still shows > */
	}

	#section_nav li.active li:last-of-type {
		border-right: none;
	}

	#section_nav li ul li.active a {
		color: #89062C;
		font-weight: bold;
	}

	#section_nav li ul li a:hover {
		text-decoration: none;
	}

/*
	 _                                        
	| |_  ___ _ __  ___   _ __  __ _ __ _ ___ 
	| ' \/ _ \ '  \/ -_) | '_ \/ _` / _` / -_)
	|_||_\___/_|_|_\___| | .__/\__,_\__, \___|
						 |_|        |___/     
	home page */

	#brandingBar {
		height: auto;
		width: auto;
	}

	#leftBar {
		margin-left: -15px;  /* to offset class="row" */
		margin-right: -15px; /* to offset class="row" */
		height: 280px;
		padding-top: 0;
		width: calc(100% + 30px);
		float: none;
	}

	#leftBar #search {
		width: auto;
		height: auto;
		margin: 0;
		float: none;
	}

	#leftBar .formSearch {
		float: none;
		width: auto;
		margin: 0;
		padding-top: 200px;
		padding-left: 27px;
	}

	#leftBar #stylized input.promo {
		width: 215px;
	}

	#bannerBar {
		padding: 0;
		width: auto;
	}

	#bannerLeft {
		margin-left: -15px;  /* to offset class="row" */
		margin-right: -15px; /* to offset class="row" */
		float: none;
		height: auto;
		width: auto;
	}

	#bannerLeft img {
		height: auto !important;
		width: 100% !important;
	}

	#bannerLeft p {
		margin: 0;
	}

	#bannerRight {
		margin-left: -15px;  /* to offset class="row" */
		margin-right: -15px; /* to offset class="row" */
		float: none;
		height: auto;
		width: auto;
	}

	#bannerRight p {
		margin: 0;
	}

	#bannerRight img {
		width: 100% !important;
		height: auto !important;
	}

	.home_footer {
		margin: 0;
		margin-left: -15px;  /* to offset class="row" */
		margin-right: -15px; /* to offset class="row" */
		width: auto;
		overflow-x: auto;
	}

/*
     _             _      
  __(_)__ _ _ _   (_)_ _  
 (_-< / _` | ' \  | | ' \ 
 /__/_\__, |_||_| |_|_||_|
      |___/               

user login,
checkout login */

	#left,
	#right,
	#leftCheckout, #rightCheckout {
		float: none;
		margin: 20px 0 0 0;
		width: 100%;
		border: 0;
		padding: 0;
	}

	#user-login #form_container h1,
	#checkout-login #form_container h1 {
		width: auto;
		height: auto;
		margin: 0 -15px 15px;
		color: white;
		background: #89052C;
		padding: 10px 20px;
		font: normal 18px/30px Verdana, sans-serif;
	}

	#user-login .buttons button.positive,
	#checkout-login .buttons button.positiveL {
		margin-left: 0;
	}

	.formAccount {
		padding-bottom: 20px;
    	border-bottom: 1px solid #c0c0c0;
	}

	.rowElemAccount,
	.rowElemAccount2 {
		float: none;
		width: 100%;
	}

	#stylized .rowElemAccount label,
	#stylized .rowElemAccount label,
	#stylized .rowElemAccount2 label {
		text-align: left;
		float: none;
		width: auto;
	}

	/* inputs */
	#stylized.formAccount .rowElemAccount .login,
	#stylized .rowElemAccount .login,
	#stylized .rowElemAccount select,
	#stylized .rowElemAccount2 select {
		margin-left: 0;
		margin-bottom: 5px;
		width: 100%;
		height: 40px;
	}

	#stylized input.login,
	#stylized select,
	input#addr_state {
		width: calc(100% - 20px);
		height: 40px;
		margin-left: 0;
	}

	.create-an-account input#addr_state {
		width: 100%;
		margin: 0 0 5px;
	}

	#right .buttons button {
		margin-left: 0;
		margin-bottom: 5px;
	}

	.selectAddress {
		float: none;
		width: auto;
	}

	#stylized .buttons .label_space,
	#right .label_space {
		display: none;
	}

	#stylized.form {
		float: none;
		width: 100%;
	}

	#right .rowElemAccount .wrap {
		width: 75%;
	}

	.buttons {
		clear: both;
	}

	.buttons.multi-buttons {
		padding-left: 0;
	}

	.formAccount .buttons,
	.formAccount2 .buttons {
		padding-top: 20px;
	}

	#right .buttons {
		margin-bottom: 50px;
	}

	.formAccount2 {
		border-bottom: 1px solid #c0c0c0;
		padding-bottom: 20px;
	}


/*
                                             _   
  _  _ ___ ___ _ _   __ _ __ __ ___ _  _ _ _| |_ 
 | || (_-</ -_) '_| / _` / _/ _/ _ \ || | ' \  _|
  \_,_/__/\___|_|   \__,_\__\__\___/\_,_|_||_\__|
                                                 
user account */

	/* logged in nav */
	#welcomeMessage {
		display:none;
	}

	#user-account .profile {
		width: auto;
		float: none;
		margin-right: 0;
	}

	.profile form {
		width: auto;
		float: none;
		border: 0;
		padding-bottom: 0;
	}

	.formAccount2,
	.rowElemAccount2 {
		float: none;
		width: auto;
	}

	#stylized label.account {
		text-align: left;
		width: auto;
		float: none;
	}

	#user-account input.login,
	#user-account #addr_state {
		width: 100%;
		height: 40px;
		margin-left: 0;
	}

	#user-account select#addr_country {
		margin-left: 0;
		margin-bottom: 5px;
		width: 100%;
		height: 40px;
	}

	#user-account h2 {
		margin: 0;
	}

	#user-account .order_history tr td,
	#user-account .order_history tr th {
		padding: 5px 3px;
		font-size: 12px;
	}

	#user-account th {
		vertical-align: top;
	}

	#user-account .buttons button {
		margin-left: 0;
	}

	#stylized .buttons label.account {
		display: none;
	}

	/* profile center (page that shows when you have an account, but not really) */

	#profile-center .checkout_form h2 {
		width: auto;
		height: auto;
		padding-top: 10px;
		padding-bottom: 10px;
		margin: 0 -15px 25px;
		clear: both;
	}

	#profile-center .label_space {
		float: none;
		width: 100%;
		text-align: left;
	}

	#profile-center #firstName,
	#profile-center #lastName,
	#profile-center #company,
	#profile-center #address1,
	#profile-center #address2,
	#profile-center #city,
	#profile-center #addr_state,
	#profile-center #zip,
	#profile-center #addr_country,
	#profile-center #phone {
		margin-left:0;
		width: 100%;
		height: 40px;
	}

	#profile-center .mailing {
		width: 100%;
	}

	#profile-center .mailing label {
		width: 100%;
		text-align: left;
		margin-left: 0;
	}

	#profile-center .mailing input#mailingList {
		margin: 0 5px 0 0;
	}


/*
                   _         _       __          _                         
  _ __ _ _ ___  __| |_  _ __| |_    / /  __ __ _| |_ ___ __ _ ___ _ _ _  _ 
 | '_ \ '_/ _ \/ _` | || / _|  _|  / /  / _/ _` |  _/ -_) _` / _ \ '_| || |
 | .__/_| \___/\__,_|\_,_\__|\__| /_/   \__\__,_|\__\___\__, \___/_|  \_, |
 |_|                                                    |___/         |__/ 

category list page */

	/* header image */
	#smallBrandingBarImage {
		margin-left: -15px;
		margin-right: -15px;
		width: auto;
		overflow: hidden;
	}

	.category-list div.categoryImg {
		width: auto;
	}

	#productContainer {
		width: auto;
		float: none;
	}

	
	/* category detail (and category list shares much of this) */

	#prodList,
	#prodList h1 {
		width: auto;
		float: none;
	}

	#productItems {
		width: auto;
		float: none;
		overflow: hidden;
		margin-bottom: 20px;
	}

	#productItems p {
		margin-top: 0;
	}

	div.categoryImg {
		text-align: left;
		display: block;
		width: 25%;
		max-width: 182px;
		margin: 0 10px 0 0;
	}

	.product_spacer {
		max-width: 100%;
		visibility: hidden;
	}

	#creator_overlay_thumb {
		float: none;
		width: 100%;
	}

	#creator_overlay_thumb img {
		max-width: 100%;
	}

	.productDetail {
		width: auto;
		float: none;
		margin-left: 28%;
	}

	/* facebook button */
	.like {
		position: absolute;
		top: -32px;
		right: -15px;
	}

	/* header image */

	#smallBrandingBarImage {
		margin-left: -15px;
		margin-right: -15px;
	}


/*
   __                                      _           
  / _|_ _ __ _ _ __  ___   __ _ _ ___ __ _| |_ ___ _ _ 
 |  _| '_/ _` | '  \/ -_) / _| '_/ -_) _` |  _/ _ \ '_|
 |_| |_| \__,_|_|_|_\___| \__|_| \___\__,_|\__\___/_|  
                                                       														
frame creator */

	.size_selector {
		width: auto;
		float: none;
	}

	#selector_1 {
		padding-top: 0; /* remove padding when 2+ selectors are present */
	}

	#container {
		clear: both;
	}

	#productHolder {
		clear: both;
	}

	#productHolder > img { /* this is the loader.gif */
		margin: 0 auto;
		display: block;
		max-width: 100%;
	}

	#creator_canvas {
		float: none;
		width: auto;
		height: auto;
		margin: 0;
		border: 0;
		width: calc(100vw - 15px);
		margin-left: -15px;
		padding-top: 15px;
	}


	/* moulding selection, outer mat color, etc */

	#creator_options {
		width: 100%;
		height: auto;
	}

	#basePrice {
		float: none;
		border: none;
		border-top: 1px solid #c0c0c0;
		margin-top: 20px;
		line-height: 40px;
		width: calc(100vw - 15px);
		margin-left: -15px;
	}

	#basePrice + br {
		display: none;
	}

	#accordion .ui-accordion-header {
		border: 0;
		border-top: 1px solid #c0c0c0;
		padding-top: 10px;
		padding-bottom: 10px;
		font-size: 12px;
		width: calc(100vw - 15px);
		margin-left: -15px;
	}

	#accordion .ui-accordion-content {
		height: auto !important;
		max-height: 450px;
	}

	.chops {
		float: none;
		padding: 0;
	}

	.chops:after {
		content: " ";
		position: absolute;
		width: 99%;
		border-top: 1px solid #c0c0c0;
	}

	.chops img {
		float: right;
		padding: 15px 5px 0 0;
		clear: both;
	}

	.ui-widget input[type="radio"] {
		margin: 15px 5px 25px 0;
	}

	#accordion .ui-widget-content,
	.ui-accordion .ui-accordion-content,
	#accordiaon .ui-widget-content {
		border: 0 !important;
	}

	.vertical-spacer {
		min-height: 0;
		padding-bottom: 15px;
	}

	.vertical-spacer img {
		padding-right: 15px;
	}

	#creator_canvas .product_img {
		max-width: 100%;
		padding-right: 15px;
		margin-top: 15px;
	}

	#creator_overlay {
		top: 0;
	}

	/* embossing text input */
	input[class^="option_child_"] {
		width: 100%;
		height: 40px;
		font-size: 16px;
	}

	#section_content #glass-options {
		margin-top: 10px;
		font-size: 11px;
	}

	/* the container around the pricing */

	#creator_pricing {
		width: 100%;
		float: none;
		border: 0;
	}

	.creator_price,
	.creator_quantity {
		height: auto;
		overflow: hidden;
		line-height: 30px;
	}

	.creator_quantity {
		margin-bottom: 20px;
	}

	input.quantity {
		width: 45px;
	}

	#creator_pricing .buttons {
		overflow: hidden;
	}

	/* color picker in accordion */

	.sp-container.sp-flat {
		width: 100%;
	}

	.sp-container .sp-picker-container {
		float: none;
		padding: 0;
		margin: 0 auto;
		width: 50vw;
		max-width: 300px;
		min-width: 200px;
	}

	/* hide permalink */

	#d_clip_container {
		display: none;
	}

/*
         _             _                       _    
  ___ __| |_  ___  ___| |  ___ ___ __ _ _ _ __| |_  
 (_-</ _| ' \/ _ \/ _ \ | (_-</ -_) _` | '_/ _| ' \ 
 /__/\__|_||_\___/\___/_| /__/\___\__,_|_| \__|_||_|
                                                    
school search page */

	.formSearch2 {
		float: none;
		width: auto;
		clear: left;
		margin: 0;
	}

	.formSearch2 #frmSearch {
		margin: 20px 0;
		float: none;
		width: auto;
		padding: 20px 15px;
	}

	.rowElem,
	.rowElem2 {
		float: none;
		width: auto;
	}

	#school-search #state {
		width: 100%;
		background: white;
		height: 40px;
	}

	.formSearch2#stylized input.search_text {
		margin-left: 0;
		width: 100%;
		height: 40px;
	}

	.formSearch2 button.positive {
		float: none;
		margin-left: 0;
	}

	.tablesorter + h4 {
		line-height: 1.42857143;
	}

	.cbox_messagebox_warning {
		width: auto;
	}

	/* cart */

	/* for h1's directly following navs */
	#section_content > h1 {
		padding-top: 10px;
	}

	.d-thead {
		display: none;
	}

	.d-tr {
		display: block;
		position: relative;
	}

	.d-td {
		display: block;
	}

	.cart-description {
		margin-left: 96px;
	}

	#checkout-review .cart-description {
		margin-left: 0;
	}

	.cart-description ul {
		padding-left: 20px;
	}

	.cart-unit-price,
	.cart-quantity,
	.cart-subtotal {
		position: relative;
		text-align: right;
		padding-top: 5px;
	}

	.d-td.cart-image:before,
	#checkout-review .cart-description:before,
	#checkout-complete .cart-description:before {
		content: "Product:";
		display: block;
		font-weight: bold;
		margin-top: 14px;
		margin-bottom: 20px;
	}

	#checkout-review .cart-description:before,
	#checkout-complete .cart-description:before {
		margin-top: 0;
		margin-bottom: 10px;
		color: #999;
	}

	#checkout-review .cart-quantity:before,
	#checkout-review .cart-unit-price:before,
	#checkout-review .cart-subtotal:before {
		left: 10px;
	}

	.cart-unit-price:before {
		content: "Price:";
		font-weight: bold;
		position: absolute;
		left: 15px;
	}

	.cart-quantity:before {
		content: "Quantity:";
		font-weight: bold;
		position: absolute;
		left: 15px;
	}

	#cart-display .cart-quantity:before {
		top: 10px;
	}

	.cart-subtotal:before {
		content: "Subtotal:";
		font-weight: bold;
		position: absolute;
		left: 15px;
	}

	.cart-table #creator_overlay_thumb img {
		max-width: none;
	}

	.cart-table input.quantity {
		float: none;
		margin-right: 0;
	}

	#cart-display .buttons {
		clear: none;
	}

	#cart-display #checkoutForm button {
		margin-left: 10px;
	}

	#cart-display #continueShoppingForm button {
		margin-left: 0;
	}

	.d-tbody .cart-subtotal {
		padding-top: 5px;
		margin-bottom: 20px;
	}

	.d-tbody .d-tr {
		border-bottom: 1px solid #C0C0C0;
	}

	.d-tbody .d-tr:last-of-type {
		border: 0;
	}

	.cart-action {
		position: absolute;
		top: 10px;
		right: 0;
	}

	.totals_bar {
		float: none;
		width: 100%;
		overflow: hidden;
	}

	.taxDisclaimer {
		top: 0;
	}

	.review_totals {
		float: none;
		width: 100%;
	}

	.review_totals tr td:first-child {
		text-align: left;
	}

	.review_totals tr td {
		padding-left: 15px;
		padding-right: 15px;
	}

	.formControls {
		width: auto;
		margin-right: 0;
	}

	#stylized .promo label {
		float: none;
		text-align: left;
		width: auto;
	}

	#stylized .promo input.promo {
		width: 60%;
		margin-left: 0;
	}

	.categoryName {
		font-weight: bold;
	}


	/* checkout review */

	#checkout-review .checkout_form h2,
	#checkout-review .cc_form h2 {
		width: auto;
		height: auto;
		padding-top: 10px;
		padding-bottom: 10px;
		margin: 0 -15px 25px;
	}

	#leftReview,
	#rightReview {
		width: 100%;
		border: 0;
		margin-bottom: 30px;
		padding: 0;
	}

	#leftReview:after {
		position: absolute;
		content: " ";
		height: 1px;
		left: 0;
		right: 0;
		background: #c0c0c0;
		margin-top: 15px;
	}

	#checkout-review .d-table {
		margin-bottom: 30px;

	}

	#checkout-review .promo_code select,
	#checkout-review .promo_code .label_space {
		width: 100%;
	}

	#checkout-review .promo_code select {
		height: 40px;
		margin: 0 0 10px;
	}

	#checkout-review #comments {
		width: 100%;
		height: 6em;
		padding: 6px;
	}

	/* credit card - overwrite inline styles */
	.credit_card_info {
		padding: 0;
		border: 0;
		width: 100%;
		float: none;
	}

	.cc_number,
	.expiration {
		float: none;
		width: 100%;
		clear: both;
		overflow: hidden;
	}
	
	.date_separator, 
	.month, 
	.year, .cc_name {
		padding: 10px;
	}

	.expiration {
		margin-bottom: 10px
	}

	.credit_card,
	.security_code {
		width: 49%;
	}

	.credit_card {
		margin-right: 2%;
	}

	.cc_number input,
	.credit_card input,
	.credit_card select, 
	.security_code input, 
	.expiration input,
	.cc_name input {
		height: 40px;
		width: 100%;
		margin-left: 0;
	}

	.security_code input {
    	margin: 0 0 7px;
	}

	#checkout-review .d-tbody .cart-quantity {
		padding-top: 5px;
	}

	#checkout-review .credit_card_info label {
		display: block !important;
		margin-left: 0 !important;
		float: none !important;
		width: 100% !important;
	}

	#checkout-review select {
		margin-left: 0;
		height: 40px;
	}

	#checkout-review .security_code label.cc {
		text-align: left !important;
	}

	#checkout-review .buttons button {
		margin-left: 10px;
	}

	#checkout-review p.review,
	#order-display p.review,
	#checkout-complete p.review {
		float: none;
		margin: 0 0 4px;
	}

	#checkout-review .promo_code {
		padding: 10px 0 15px;
		border: 0;
	}

	#checkout-review .promo_code:after {
		position: absolute;
		content: " ";
		height: 1px;
		left: 0;
		right: 0;
		background: #c0c0c0;
		margin-top: 15px;
	}

	#checkout-review .totals_bar {
		width: auto;
		margin-left: -15px;
		margin-right: -15px;
		border-left: 0;
		border-right: 0;
		margin-bottom: 25px;
	}

	/* checkout complete */

	#checkout-complete #continueShoppingForm + button.positiveR,
	#checkout-complete #continueShoppingButton {
		margin: 10px 0 10px 10px;
		height: 40px;
	}

	#checkout-complete .checkout_form h2 {
		width: auto;
		height: auto;
		padding-top: 10px;
		padding-bottom: 10px;
		margin: 0 -15px 25px;
		clear: both;
	}

	.confirmation_bottom {
		width: 100%;
	}

	#checkout-complete .cart-description {
		margin-left: 0;
	}

	/* Order display */

	#order-display .checkout_form h2 {
		width: auto;
		height: auto;
		padding-top: 10px;
		padding-bottom: 10px;
		margin: 0 -15px 25px;
	}

	#order-display .cart-description {
		margin-left: 0;
	}

	#order-display .shopping_cart,
	#checkout-complete .shopping_cart {
		float: none;
		width: 100%;
		border: 0;
	}

	#order-display th.cart_product_head,
	#checkout-complete th.cart_product_head {
		padding: 10px 0;
	}

	#order-display .shopping_cart td,
	#checkout-complete .shopping_cart td {
		padding: 0;
	}

	#order-display tr:last-of-type td,
	#checkout-complete tr:last-of-type td {
		padding-bottom: 25px
	}

	#order-display .totals_bar,
	#checkout-complete .totals_bar {
		width: auto;
		margin-left: -15px;
		margin-right: -15px;
		border-left: 0;
		border-right: 0;
		margin-bottom: 25px;
		border-top: 1px solid #c0c0c0;
	}

	#order-display .cart-table,
	#checkout-complete .cart-table {
		margin-bottom: 25px
	}

	.cart-quantity .formCartUpdate {
		float: none;
		width: auto;
	}

	.cart-quantity #stylized input.date {
		float: none;
	}


/*
  _    _ _ _ _               __     _    _           _           
 | |__(_) | (_)_ _  __ _    / /  __| |_ (_)_ __ _ __(_)_ _  __ _ 
 | '_ \ | | | | ' \/ _` |  / /  (_-< ' \| | '_ \ '_ \ | ' \/ _` |
 |_.__/_|_|_|_|_||_\__, | /_/   /__/_||_|_| .__/ .__/_|_||_\__, |
                   |___/                  |_|  |_|         |___/ 

checkout/billing */

	.checkout_progress {
		float: none;
		border: 0;
		overflow: hidden;
		margin: 0;
	}

	/* this is for both billing and shipping */
	.required_label {
		line-height: 1;
		height: auto;
		position: absolute;
		right: 0;
		margin-top: 56px;
		margin-right: 20px;		
	}

	#stylized2.billing h2,
	#billing-shipping-review #stylized2 h2 {
		width: auto;
		height: auto;
		padding-top: 10px;
		padding-bottom: 10px;
		margin: 0 -15px 25px;
	}

	#frmBilling {
		float: none;
	}

	.shipping_info {
		width: 100%;
		float: none;
		border: 0;
		padding: 0;
	}

	.formControls {
		width: auto;
		height: auto;
	}

	.name_first,
	.name_last,
	.company,
	.address,
	.address_line2,
	.city,
	.state,
	.zip,
	.country,
	.email,
	.phone,
	.emailOptIn {
		width: 100%;
		float: none;
		clear: both;
		margin-bottom: 5px;
		padding-top: 5px;
	}

	.state,
	.zip {
		width: 49%;
		float: left;
		clear: none;
	}
	.state {
		margin-right: 2%;
	}

	.label-reset {
		width: auto;
		float: none;
		text-align: left;
		margin: 0;
		padding: 5px 0;
	}

	/* all the billing labels */
	#stylized2.billing label {
		float: none;
		width: auto;
		text-align: left;
	}

	/* all the billing inputs and selects */
	#stylized2.billing input,
	#stylized2.billing select {
		width: 100%;
		margin: 0;
		height: 40px;
	}

	/* well, not ALL the inputs... */
	#stylized2.billing input#emailOptIn {
		width: auto;
		height: auto;
	}

	/* checkout shipping */

	#checkout-shipping .checkout_form h2 {
		width: auto;
		height: auto;
		padding-top: 10px;
		padding-bottom: 10px;
		margin: 0 -15px 35px;
	}

	#frmShipping {
		float: none;
	}

	#checkout-shipping label.duplicate-label {
		float: none;
		width: 100%;
	}

	#checkout-shipping .duplicate_shipping,
	#checkout-shipping #addressType {
		width: 100%;
		margin-left: 0;
	}

	#checkout-shipping .label_space {
		float: none;
		width: 100%;
		text-align: left;
	}

	#shippingFirstname,
	#shippingLastname,
	#shippingCompany,
	#shippingAddress1,
	#shippingAddress2,
	#shippingCity,
	#addr_state,
	#shippingZip,
	#addr_country,
	#shippingEmail,
	#shippingPhone {
		margin-left:0;
		width: 100%;
		height: 40px;
	}

	#addr_state {
		height: 40px;
		margin: 2px 0 0;
	}

	#checkout-billing .address,
	#checkout-shipping .address,
	#shippingAddress1 {
		margin-bottom: 0;
	}

	#checkout-shipping #state_text {
		width: 100%;
		margin: 2px 0 0;
		height: 40px;
		background: #ffffcc;
	}

	#checkout-shipping label.shipping {
		width: 100%;
		margin-bottom: 10px;
	}

	/* shipping option radios */

	#checkout-shipping .shipping_radios {
		float: none;
	}

	#checkout-shipping .shipping input {
		margin-bottom: 25px;
	}

	/* shipping options box */
	#checkout-shipping .shipping_options {
		padding: 0;
		border: 0;
		float: none;
	}

	#checkout-shipping .shipping_options h3 {
		font-weight: bold;
		padding: 20px 0;
	}

	#checkout-shipping .shipping_options p {
		padding: 0 0 20px;
	}

	#checkout-shipping .buttons button {
		margin-left: 10px;
	}

	/* billing shipping review (for CSR accounts) */


	#billing-shipping-review label {
		float: none;
		text-align: left;
	}

	#billing-shipping-review #billingFirstname,
	#billing-shipping-review #billingLastname,
	#billing-shipping-review #billingCompany,
	#billing-shipping-review #billingCompany2,
	#billing-shipping-review #billingAddress1,
	#billing-shipping-review #billingAddress2,
	#billing-shipping-review #billingCity,
	#billing-shipping-review #billingZip,
	#billing-shipping-review #billingStateUS,
	#billing-shipping-review #billingStateCA,
	#billing-shipping-review #billingStateOther,
	#billing-shipping-review #billingCountry,
	#billing-shipping-review #billingEmail,
	#billing-shipping-review #billingDaytimePhone,
	#billing-shipping-review #billingEveningPhone,
	#billing-shipping-review #shippingCompany2,
	#billing-shipping-review #shippingStateUS,
	#billing-shipping-review #shippingStateCA,
	#billing-shipping-review #shippingStateOther,
	#billing-shipping-review #shippingCountry,
	#billing-shipping-review .check_number input,
	#billing-shipping-review .check_amount input,
	#billing-shipping-review .check_date input {
		margin-left:0;
		width: 100%;
		height: 40px;
	}

	#billing-shipping-review #comments {
		margin-left:0;
		width: 100%;
	}

	#billing-shipping-review #totals {
		overflow-x: auto;
	}

	#billing-shipping-review .check_number,
	#billing-shipping-review .check_amount,
	#billing-shipping-review .check_date {
		float: none;
	}

	#billing-shipping-review #addressType {
		width: auto;
	}

	#billing-shipping-review #stylized2 label.cc {
		margin-left: 0;
	}

	#billing-shipping-review .formControls button {
		margin-top: 10px;
		height: 40px;
	}

	#clearOrderContainer .formControls button {
		height: 40px;
	}


	/* product list */

	#prodList,
	#prodList h1 {
		width: auto;
		height: auto;
		float: none;
		position: relative; /* used for 'like' button */
	}
	#prodList h1 {
		margin-bottom: 20px;
	}


/*
             _           _
  __ ___ _ _| |_ ___ _ _| |_   _ __  __ _ __ _ ___ ___
 / _/ _ \ ' \  _/ -_) ' \  _| | '_ \/ _` / _` / -_|_-<
 \__\___/_||_\__\___|_||_\__| | .__/\__,_\__, \___/__/
                              |_|        |___/

content pages */

	.content-page img {
		max-width: 100% !important;
		height: auto !important;
	}

	.content-page object {
		width: 100% !important;
	}

	.content-page iframe {
		width: 100%;
	}

	.content-table {
		overflow-x: auto;
	}

	/* contact us */

	#bigBrandingBarImage {
		width: auto;
		height: auto;
	}

	#left_contact,
	#right_contact {
		float: none;
		width: auto;
		padding: 0;
		border: none;
	}

	#form_container_contact {
		float: none;
		width: auto;
	}

	#left_contact form {
		padding: 0;
		width: auto;
	}

	#left_contact form label {
		width: auto;
		text-align: left;
	}

	#left_contact #stylized.form input,
	#left_contact #stylized.form textarea {
		width: 100%;
		margin: 0;
		float: none;
	}

	#left_contact #stylized.form input {
		height: 40px;
	}

	#left_contact #stylized.form .captcha_text {
		float: none;
		width: auto;
		margin: 10px 0;
	}

	/* partnership */

	.content-page #partnership input,
	.content-page #partnership textarea,
	.content-page #partnership select {
		width: 100%;
		margin: 0;
		float: none;
		height: 40px;
	}

	.content-page #partnership label {
		width: auto;
		text-align: left;
	}

	#stylized #partnership .captcha_text {
		float: none;
		width: auto;
		margin: 10px 0;
	}

	/* gift certificates */

	.content-page .formGC,
	.content-page #left2,
	.content-page .rowElemAccount3 {
		float: none;
		width: auto;
	}

	.content-page #stylizedGC label.gc {
		text-align: left;
	}

	.content-page #stylizedGC input {
		width: 100%;
		margin-left: 0;
		height: 40px;
	}

	.content-page #stylizedGC input.checkbox {
		width: 15px;
		height: 15px;
	}

	.content-page #creator_pricing2 {
		margin: 0;
		float: none;
		width: auto;
		height: auto;
	}

	.content-page #creator_pricing2 .buttons {
		overflow: hidden;
	}

	.content-page .creator_quantity input.quantity {
		height: 40px;
	}

	/* site-map */

	#sitemap {
		width: auto;
	}

}

@media (min-width: 768px) {

	.col-sm-8 {
		width: 67.666667%;
	}

}