pre {
	white-space: normal;
}

.jsm-fields {
	max-width: 500px; /* repeat this width on the form in func jsm_woocommerce_membership_product_quantity_using_css */
	clear: both; /* really only needed for FoHT event registration inline membership renewal */
}

.jsm-fields.login-form-container {
	min-width: 300px;
}

.jsm-field {
	margin: 0 0 10px 0;
}

.jsm-field + .jsm-field-description {
	margin: -4px 0 10px 0;
}

.jsm-field + .jsm-field-description + .jsm-field-description {
	margin: -6px 0 10px 0;
}

label + .jsm-field-description {
	margin-top: 7px;
}

.jsm-field-description {
	font-style: italic;
	font-size: 90%;
    line-height: 1.2;
}

.jsm-field-description.full-width {
    padding-left: 0;
}

.jsm-field-description .fa {
	color: #646464;
}
.jsm-field input[name^="jsm_user_pwd_"] + .fa {
	color: #303030;
}

.jsm-field-description.fa-red .fa {
	color: #E51C24; /* TODO: from php JSM_COLOUR__RED */
}

.jsm-person-row .jsm-field-description {
	display: none;
}

.jsm-person-row.active-row .jsm-field-description {
	display: block;
}

.jsm-field-description.jsm-field-description-full-width-btm {
	padding: 10px;
	margin: 25px -10px -10px -10px;
	border-top: 1px solid #ccc;
}

.jsm-field label,
.jsm-field .jsm-like-label,
.jsm-field .jsm-like-label-space {
	width: 100%;
	display: block;
    line-height: 1.2;
	margin: 0 0 7px 0;
	font-weight: bold;
}

.jsm-wsa .jsm-field label,
.jsm-wsa .jsm-field .jsm-like-label,
.jsm-wsa .jsm-field .jsm-like-label-space {
    font-weight: 300;
}

.jsm-field label[for^="jsm_user_tw_subscribe_"] {
	font-weight: 400;
}

.jsm-field.mailchimp_user_subscriptions .mailchimp_subscriptions label {
	font-weight: 400;
}

.jsm-field input[type="text"],
.jsm-field input[type="number"],
.jsm-field input[type="email"],
.jsm-field input[type="url"],
.jsm-field input[type="tel"],
.jsm-field input[type="password"],
.jsm-field textarea,
.jsm-field select {
	width: 100%;
    box-sizing: border-box;
	font-size: 1em;
	line-height: 1.1;
	line-height: 15px;
	padding: 6px 9px 6px 9px;
	border-style: solid;
	border-width: 1px;
	border-radius: 0;
}

.jsm-field input[name^="jsm_user_pwd_"] + .fa {
    margin-left: -30px;
    cursor: pointer;
}

.jsm-field select {
	padding: 6px 9px 5px 9px;
}

.jsm-field .jsm-repeater-input input[type="text"],
.jsm-field .jsm-repeater-input input[type="number"],
.jsm-field .jsm-repeater-input input[type="email"],
.jsm-field .jsm-repeater-input input[type="url"],
.jsm-field .jsm-repeater-input input[type="tel"],
.jsm-field .jsm-repeater-input input[type="password"],
.jsm-field .jsm-repeater-input textarea,
.jsm-field .jsm-repeater-input select,
.jsm-field .jsm-repeater-input input[type="text"].full-width,
.jsm-field .jsm-repeater-input input[type="number"].full-width,
.jsm-field .jsm-repeater-input input[type="email"].full-width,
.jsm-field .jsm-repeater-input input[type="url"].full-width,
.jsm-field .jsm-repeater-input input[type="tel"].full-width,
.jsm-field .jsm-repeater-input input[type="password"].full-width,
.jsm-field .jsm-repeater-input textarea.full-width,
.jsm-field .jsm-repeater-input select.full-width {
	width: 100%;
	width: calc(100% - 64px);
}

.jsm-field.password-with-toggle {
    overflow: auto;
}

.jsm-field.password-with-toggle input[type="text"],
.jsm-field.password-with-toggle input[type="password"] {
    width: calc(100% - 42px);
    border-right: 0;
    
    float: left;
}

.jsm-field.password-with-toggle .password-toggle-wrapper {
    width: 42px;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: space-evenly;
    background: #eee;
    border: 1px solid #ccc;
    border-left: 0;
    color: #000;
    text-decoration: none;
    
    float: left;
    min-height: 29px;
}

.jsm-field.password-with-toggle .password-toggle-wrapper .password-toggle {
    margin-top: -1px;
    color: #000;
}

.jsm-field.password-with-toggle .password-toggle-wrapper:hover {
    text-decoration: none;
}

.jsm-field.password-with-toggle .password-toggle-wrapper:hover .password-toggle {
    filter: drop-shadow(0px 0px 6px #e51c24);
}

.jsm-repeater-inputs {
	width: 100%;
}

.jsm-field .jsm-repeater-input {
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
	margin: 5px 0;
}

.jsm-field .full-width .jsm-repeater-input {
	width: 100%;
}

.jsm-field .jsm-repeater-input.jsm-repeater-input-hidden {
	display: none;
}

.jsm-other-email-address-row-actions {
	min-width: 56px;
	margin-left: 5px;
}

.jsm-other-email-address-row-actions-btn {
	margin: 4px 3px;
	font-size: 26px;
	line-height: 24px;
	display: block;
	height: 26px;
	float: left;
}

.jsm-other-email-address-row-actions-btn.add-other-email-address-row {
	float: right;
	display: none;
}

.current-last-row .jsm-other-email-address-row-actions-btn.add-other-email-address-row {
	display: block;
}

.jsm-other-email-address-row-actions-btn-hidden {
	display: none;
}

.jsm-other-email-address-row-actions-btn-hidden + .jsm-other-email-address-row-actions-btn {
	margin-left: 26px;
}

.jsm-other-email-address-row-actions {
	float: left;
}

.jsm-person-rows {
	margin-top: 15px;
}

.jsm-person-rows .jsm-person-row {
	border: 1px solid #646464;
	position: relative;
	padding: 35px 10px 10px 10px;
	margin: 20px 0 20px 0;
}

.jsm-person-rows > .jsm-person-row:first-child {
	margin-top: 0;
}

.jsm-person-rows .jsm-person-row.current-last-row {
	padding-bottom: 35px;
    padding-bottom: 70px;
}

.jsm-person-rows .jsm-person-row .jsm-person-row-label {
	background: #646464;
    color: #fff;
    display: inline-block;
    padding: 0 10px;
    font-size: 90%;
    position: absolute;
    top: 0;
    left: 0;
}

.jsm-person-rows .jsm-person-row .jsm-person-row-actions {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    background: #fff;
    border-top: 1px solid #ccc;
	padding: 0 3px;
	display: none;
}

.jsm-person-rows .jsm-person-row.current-last-row .jsm-person-row-actions .jsm-person-row-actions-btn {
	cursor: pointer;
}

.jsm-person-rows .jsm-person-row .jsm-person-row-actions .jsm-person-row-actions-description {
	display: none;
	color: #646464;
	font-style: italic;
	font-size: 90%;
	float: left;
	margin: 4px 4px;
	line-height: 26px;
	max-width: calc(100% - 65px);
}

.jsm-person-rows .jsm-person-row.current-last-row .jsm-person-row-actions {
	display: block;
}

.jsm-person-rows .jsm-person-row.current-last-row  .jsm-person-row-actions .jsm-person-row-actions-description {
	display: block;
}

.jsm-person-row-actions-btn {
    float: right;
    margin: 4px 3px;
    font-size: 26px;
    line-height: 24px;
    display: block;
    height: 26px;
}

.jsm-person-rows[max-num-ppl="1"] .jsm-person-row {
	border: 0;
	padding: 10px 0 10px 0;
	margin-bottom: 0;
}

.jsm-person-rows[max-num-ppl="1"] .jsm-person-row .jsm-person-row-label,
.jsm-person-rows[max-num-ppl="1"] .jsm-person-row .jsm-person-row-actions {
	display: none;
}

.ui-datepicker {
	z-index: 1000 !important;
}

/*
NO, let's customise the wc template cart-item-data.php
.woocommerce td.product-name dl.variation dt[class*="FirstName"],
.woocommerce td.product-name dl.variation dt[class*="LastName"],
.woocommerce td.product-name dl.variation dt[class*="Email"],
.woocommerce td.product-name dl.variation dt[class*="Password"],
.woocommerce td.product-name dl.variation dt[class*="DOB"],
.woocommerce td.product-name dl.variation dt[class*="Phone"] {
	float: left;
	clear: left;
    width: auto;
	margin-right: 4px;
}
 
.woocommerce td.product-name dl.variation dd[class*="FirstName"],
.woocommerce td.product-name dl.variation dd[class*="LastName"],
.woocommerce td.product-name dl.variation dd[class*="Email"],
.woocommerce td.product-name dl.variation dd[class*="Password"],
.woocommerce td.product-name dl.variation dd[class*="DOB"],
.woocommerce td.product-name dl.variation dd[class*="Phone"] {
	float: left;
	width: auto;
}
*/

.woocommerce td.product-name .jsm-user-data p {
	margin: 0;
}

.woocommerce td.product-name .jsm-user-data th.variation-jsm-person-header-th {
	font-weight: bold;
	border-top: 1px solid #000 !important;
	background: #ccc;
	padding: 3px 6px 0 6px;
	line-height: 1.2;
}

.woocommerce td.product-name .jsm-user-data th.variation-jsm-person-th {
	font-weight: 400;
	padding: 3px 6px 1px 6px;
	line-height: 1.2;
	white-space: nowrap;
	border-top: 1px solid #ccc;
	text-align: right;
}

.woocommerce td.product-name .jsm-user-data th.variation-jsm-person-th.variation-jsm_lifetime,
.woocommerce td.product-name .jsm-user-data th.variation-jsm-person-th[class^="variation-jsm_user_mc_subscribe_"] {
	white-space: normal;
}

.woocommerce .jsm-user-data .variation-jsm-person-th p,
.woocommerce .jsm-user-data .variation-jsm-person-td p {
	margin-bottom: 0;
}

.woocommerce td.product-name .jsm-user-data td.variation-jsm-person-td {
	padding: 3px 6px 1px 6px;
	line-height: 1.2;
	border-top: 1px solid #ccc;
}

.woocommerce td.product-name .jsm-user-data tbody > tr:last-child th.variation-jsm-person-th,
.woocommerce td.product-name .jsm-user-data tbody > tr:last-child td.variation-jsm-person-td {
	border-bottom: 1px solid #000 !important;
}

.woocommerce td.product-name .jsm-user-data.num-of-ppl-rows-1 tbody > tr:last-child th.variation-jsm-person-th,
.woocommerce td.product-name .jsm-user-data.num-of-ppl-rows-1 tbody > tr:last-child td.variation-jsm-person-td {
	border-bottom: 1px solid #ccc !important;
}

.woocommerce td.product-name .jsm-user-data td.variation-jsm-person-spacer-row-td {
	padding: 7px 0;
	font-size: 1px !important;
	border-top: 1px solid #000;
}

.woocommerce td.product-name .jsm-user-data th.variation-jsm-membership-data,
.woocommerce td.product-name .jsm-user-data td.variation-jsm-membership-data {
	padding: 3px 6px 1px 6px;
	line-height: 1.2;
	border-top: 1px solid #ccc !important;
}

.woocommerce td.product-name .jsm-user-data th.variation-jsm-membership-data {
	font-weight: 400;
	text-align: right;
}

.woocommerce td.product-name .jsm-user-data tr.variation-jsm-membership-data + tr.variation-jsm-person-spacer-row td.variation-jsm-person-spacer-row-td {
	border-top: 0;
}

.dont-break-out {

  /* These are technically the same, but use both */
  overflow-wrap: break-word;
  word-wrap: break-word;

  -ms-word-break: break-all;
  /* This is the dangerous one in WebKit, as it breaks things wherever */
  word-break: break-all;
  /* Instead use this non-standard one: */
  word-break: break-word;

  /* Adds a hyphen where the word breaks, if supported (No Blink) */
  -ms-hyphens: auto;
  -moz-hyphens: auto;
  -webkit-hyphens: auto;
  hyphens: auto;

}

.jsm-subheading {
	border-bottom: 1px solid #646464; /* TODO: from php JSM_COLOUR__GRAY */;
}

@media screen and (max-width: 768px) {
	.woocommerce table.shop_table_responsive .jsm-user-data tr, 
	.woocommerce-page table.shop_table_responsive .jsm-user-data tr {
		display: table-row !important;
	}
	
	.woocommerce table.shop_table_responsive .jsm-user-data tbody th, 
	.woocommerce-page table.shop_table_responsive .jsm-user-data tbody th {
		display: table-cell !important;
	}
	
	.woocommerce table.shop_table_responsive .jsm-user-data tr td::before, 
	.woocommerce-page table.shop_table_responsive .jsm-user-data tr td::before {
		content: "";
		display: none !important;
	}
	
	.woocommerce table.shop_table_responsive .jsm-user-data tr td, 
	.woocommerce-page table.shop_table_responsive .jsm-user-data  tr td {
		display: table-cell !important;
		float: none !important;
	}
	
	.woocommerce td.product-name .jsm-user-data td.variation-jsm-person-spacer-row-td {
		border-top: 1px solid #000 !important;
	}

	.woocommerce td.product-name .jsm-user-data tr.variation-jsm-membership-data + tr.variation-jsm-person-spacer-row td.variation-jsm-person-spacer-row-td {
		border-top: 0;
	}
}


@media screen and (min-width: 700px) {
	.jsm-field {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		    -ms-flex-align: center;
		        align-items: center;
		-ms-flex-wrap: wrap;
			flex-wrap: wrap;
		clear: left;
	}
	
	.jsm-field.align-label-top {
		  -webkit-box-align: start;
			  -ms-flex-align: start;
					  -ms-grid-row-align: flex-start;
				  align-items: flex-start;
	}
	
	.jsm-field.jsm-display-block {
		display: block;	
		
		/*for old IE */
		float: left;
		clear: left;
		width: 100%;
	}
	
	.jsm-field label,
	.jsm-field .jsm-like-label,
	.jsm-field .jsm-like-label-space {
		/*float: left;  don't float a flex item! Is nonsense, and causes issues in older iPads */
		float: none;
		
		clear: left;
		width: 140px;
		margin-right: 10px;
		font-weight: 400;
		margin-bottom: 0;
	}
	
	.jsm-wsa .jsm-field label,
	.jsm-wsa .jsm-field .jsm-like-label,
	.jsm-wsa .jsm-field .jsm-like-label-space {
		font-weight: 300;
	}
	
	.jsm-field label.full-width,
	.jsm-field .jsm-like-label.full-width,
	.jsm-field .jsm-like-label-space.full-width {
		/*float: left;  don't float a flex item! Is nonsense, and causes issues in older iPads */
		float: none;
		
		clear: left;
		width: 100%;
		margin-right: 0;
	}
	
	.jsm-field-description {
		padding-left: 150px;
	}
	
	.jsm-field-description.full-width {
		padding-left: 0;
	}

	.jsm-field input[type="text"],
	.jsm-field input[type="number"],
	.jsm-field input[type="email"],
	.jsm-field input[type="url"],
	.jsm-field input[type="tel"],
	.jsm-field input[type="password"],
	.jsm-field textarea,
	.jsm-field select,
	.jsm-field .jsm-like-input,
	.jsm-field .jsm-like-input-space {
		/*float: left;  don't float a flex item! Is nonsense, and causes issues in older iPads */
		float: none;
		
		box-sizing: border-box;
		width: calc(100% - 150px);
		min-width: 240px;
	}
    
    .jsm-field.password-with-toggle input[type="text"],
    .jsm-field.password-with-toggle input[type="password"] {
        width: calc(100% - 192px);
    }

	.jsm-field input[type="text"].full-width,
	.jsm-field input[type="number"].full-width,
	.jsm-field input[type="email"].full-width,
	.jsm-field input[type="url"].full-width,
	.jsm-field input[type="tel"].full-width,
	.jsm-field input[type="password"].full-width,
	.jsm-field textarea.full-width,
	.jsm-field select.full-width,
	.jsm-field .jsm-like-input.full-width,
	.jsm-field .jsm-like-input-space.full-width {
		/*float: left;  don't float a flex item! Is nonsense, and causes issues in older iPads */
		float: none;
		
		box-sizing: border-box;
		width: 100%;
	}
	
	.jsm-field .jsm-repeater-input input[type="text"],
	.jsm-field .jsm-repeater-input input[type="number"],
	.jsm-field .jsm-repeater-input input[type="email"],
	.jsm-field .jsm-repeater-input input[type="url"],
	.jsm-field .jsm-repeater-input input[type="tel"],
	.jsm-field .jsm-repeater-input input[type="password"],
	.jsm-field .jsm-repeater-input textarea,
	.jsm-field .jsm-repeater-input select,
	.jsm-field .jsm-repeater-input input[type="text"].full-width,
	.jsm-field .jsm-repeater-input input[type="number"].full-width,
	.jsm-field .jsm-repeater-input input[type="email"].full-width,
	.jsm-field .jsm-repeater-input input[type="url"].full-width,
	.jsm-field .jsm-repeater-input input[type="tel"].full-width,
	.jsm-field .jsm-repeater-input input[type="password"].full-width,
	.jsm-field .jsm-repeater-input textarea.full-width,
	.jsm-field .jsm-repeater-input select.full-width {
		width: 100%;
		width: calc(100% - 64px);
	}
	
	#password-strength-wrapper {
		width: 100%;
		padding-left: 150px;
	}
	
	#password-strength-wrapper #password-strength {
		margin-right: 0;
	}
	
	.jsm-field .password-strength,
	#confirm-weak-pwd-wrapper {
		margin-left: 150px;
		width: calc(100% - 150px);
		margin-right: 0;
	}
	
	#confirm-weak-pwd-wrapper label {
		width: 100%;
		margin-right: 0;
	}
	
	#confirm-weak-pwd-wrapper .jsm-field-description {
		padding-left: 0;
	}
	
	.jsm-field.login-remember label,
	.jsm-field input[type="submit"],
	#woocommerce-thankyou-order-received-login .jsm-field.login-submit,
	#woocommerce-thankyou-order-received-login .forgot-password {
		margin-left: 150px;
	}
	
	
	.jsm-login-page #primary .entry-content,
	.jsm-login-page #primary article,
	.jsm-login-page #primary #breadcrumbs {
		display: inline-block;
		width: 100%;
	}
	
	.jsm-login-page #primary {
		max-width: 500px;
	}
	
	.jsm-login-page #main {
		max-width: 483px;
		/*padding: 0;*/
	}
	
	.jsm_user_change_pwd_field .jsm-like-input {
		margin-left: 150px;
	}
	
	.jsm_user_change_pwd_field .password-strength,
	.jsm_user_change_pwd_field #confirm-weak-pwd-wrapper {
		width: 100%;
		margin-left: 0;
	}
	
	.jsm_user_change_pwd_field .jsm-like-input label,
	.jsm_user_change_pwd_field .jsm-like-input .jsm-field-description {
		width: 100%;
		float: none;
		padding-left: 0;
	}

}

@media screen and (max-width: 600px) {
	.woocommerce td.product-name .jsm-user-data th.variation-jsm-person-header-th,
	.woocommerce td.product-name .jsm-user-data th.variation-jsm-person-th,
	.woocommerce td.product-name .jsm-user-data td.variation-jsm-person-td {
		font-size: 90%;
	}
	
	.woocommerce td.product-name .jsm-user-data.num-of-ppl-rows-1 th.variation-jsm-person-header-th,
	.woocommerce td.product-name .jsm-user-data.num-of-ppl-rows-1 th.variation-jsm-person-th,
	.woocommerce td.product-name .jsm-user-data.num-of-ppl-rows-1 td.variation-jsm-person-td {
		font-size: 100%;
	}
}

/**
 * Front End Account styles
 */

.jsm_membership_form_div {
	margin-bottom: 35px;
}

.jsm_membership_form_div > *:first-child {
	margin-top: 0;
}

.jsm_membership_form_div > *:last-child {
	margin-bottom: 0;
}

.jsm_membership_loginform.jsm_membership_form  {
    margin-bottom: 30px;
}

.jsm_membership_form_div {
	width: 100%;
	max-width: 500px;
	float: left; /* so the top label appears correctly when there are notices above it */
}

.jsm_membership-account-nav-on-this-page-heading {
    margin-top: 0;
}

.jsm_membership-account-nav-on-this-page {
	list-style: none;
	margin: 0 0 20px 0;
}

@media screen and (min-width: 768px) {
    .jsm_membership-account-nav-on-this-page-wrapper {
        width: 18%;
        float: left;
        margin-right: 4%;
    }
    
    .jsm_membership-account-content-wrapper {
        width: 78%;
        float: left;
    }
}

.jsm-field.align-label-top .jsm-like-input > p:first-child {
	margin-top: -3px;
}


/*
 * Woocmmerce account pages (inc recover pwd)
*/

.woocommerce-account .woocommerce form {
	border: 0;
	padding: 0;
}

.woocommerce-account .woocommerce form .form-row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
}

.woocommerce-account .woocommerce form .form-row label {
	width: 150px;
	margin-right: 20px;
	display: block;
	float: left;
	clear: left;
	line-height: 1.2;
}

.woocommerce-account .woocommerce form .form-row .woocommerce-input-wrapper, 
.woocommerce-account .woocommerce-page form .form-row .woocommerce-input-wrapper,
.woocommerce-account form .form-row .woocommerce-password-strength,
.woocommerce-account form .form-row .woocommerce-password-hint {
	float: left;
	width: 75%;
	max-width: 280px;
	width: calc(100% - 170px);
}
	
.woocommerce-account .woocommerce form .form-row .screen-reader-text + .woocommerce-input-wrapper, 
.woocommerce-account .woocommerce-page form .form-row .screen-reader-text + .woocommerce-input-wrapper {
	margin-left: 170px;
}

.woocommerce-account .woocommerce form input.button {
	max-width: 280px;
}

.woocommerce-account .woocommerce form input.button,
.woocommerce-account form .form-row .woocommerce-password-strength,
.woocommerce-account form .form-row .woocommerce-password-hint {
	float: left;
	clear: left;
	margin-top: 10px;
	margin-left: 170px;
}

.woocommerce-account form .form-row .woocommerce-password-strength {
	margin-top: 0;
}

.woocommerce-account form .form-row .woocommerce-password-strength,
.woocommerce-account form .form-row .woocommerce-password-hint {
	box-sizing: border-box;
}

/* why are there <br> in there? */
.woocommerce-account .woocommerce form p.form-row br {
	display: none;
}

.woocommerce-account .woocommerce form p {
	width: 100%;
}

.woocommerce-account .woocommerce form .form-row {
	padding: 3px 0;
}

.woocommerce-account .woocommerce form .form-row-last {
	float: none;
}

@media screen and (max-width: 600px) {
	.woocommerce-account .woocommerce form .form-row label {
		width: 100%;
		margin-right: 0;
		display: block;
	}

	.woocommerce-account .woocommerce form .form-row .woocommerce-input-wrapper, 
	.woocommerce-account .woocommerce-page form .form-row .woocommerce-input-wrapper,
	.woocommerce-account .woocommerce form input.button {
		float: none;
		margin-left: 0px;
		width: 100%;
	}
	
	.woocommerce-account .woocommerce form .form-row .screen-reader-text + .woocommerce-input-wrapper, 
	.woocommerce-account .woocommerce-page form .form-row .screen-reader-text + .woocommerce-input-wrapper {
		margin-left: 0;
	}

	.woocommerce-account .woocommerce form input.button {
		width: auto;
	}
}

.jsm-form.woocommerce .woocommerce-message {
    background-color: #7FB069; /* TODO: from php JSM_COLOUR__GREEN */
    color: #fff;
    border-top: 3px solid #7FB069;
}

.jsm-form.woocommerce .woocommerce-message:before {
    color: #fff;
}

.jsm-form.woocommerce .woocommerce-message a:not(.button) {
	color: #fff !important;
	text-decoration: underline !important;
}

.jsm-form.woocommerce .woocommerce-message a.button {
	background: #fff !important;
	color: #7FB069 !important;
	margin: 0 0 5px 5px;
}

@media screen and (max-width: 699px) {
	.jsm_membership_user_subscriptions_tab_content .jsm-field {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		    -ms-flex-align: center;
		        align-items: center;
		-ms-flex-wrap: wrap;
			flex-wrap: wrap;
	}
	
	/*.jsm_membership_user_subscriptions_tab_content .jsm-field label {
		float: left;
		clear: left;
		width: 140px;
		margin-right: 10px;
	}*/
	
	.jsm_membership_user_subscriptions_tab_content .jsm-field-description {
		padding-left: 150px;
	}
	
	.jsm_membership_user_subscriptions_tab_content .jsm-field-description.full-width {
		padding-left: 0px;
	}

	.jsm_membership_user_subscriptions_tab_content .jsm-field input[type="checkbox"] {
		float: left;
		box-sizing: border-box;
	}
}


.login-info-wrapper {
	margin: 0 0 20px 0;
	overflow: auto;
}

.login-info {
	background: #7FB069;
	padding: 4px 10px;
	color: #fff;
	float: left;
	margin: 0;
}

.login-warning {
	background: #e49600;
	padding: 4px 10px;
	color: #fff;
	/*float: left;*/
	margin: 0;
}

.login-error {
	background: #E51C24; /* TODO: from php JSM_COLOUR__RED */
	padding: 4px 10px;
	color: #fff;
	float: left;
	margin: 0;
}

.login-error a:link,
.login-error a:visited,
.login-warning a:link,
.login-warning a:visited {
	color: #fff !important;
	text-decoration: underline;
}

.login-error p,
.login-warning p {
	margin-bottom: 7px;
	font-size: 110%;
}

.login-error p:last-child,
.login-warning p:last-child {
	margin-bottom: 0;
}

.login-warning p,
.login-warning p a:link, 
.login-warning p a:visited {
	color: #000 !important;
}

.password-strength {
	background-color: #eee;
	border: 2px solid #ddd;
	color: #23282d;
	text-align: center;
	box-sizing: border-box;
	opacity: 0;
}

.msg-password-strength {
	padding: 0 5px;
	margin: 0 7px;
	font-size: 80%;
}

span[id^="password-strength"] {
	margin: 0px 5px 5px 0px;
	padding: 3px 0;
	width: 100%;
	display: block;
	min-width: 161px;
}

span[id^="password-strength"] {
	min-width: 200px;
}

span[id^="password-strength"]  {
	font-weight: bold;
}

.inline-password-minimum-note {
	background: #f7f6f5;
	border: 0;
	padding: 6px 8px;
	margin: 0;
	float: left;
}

.inline-password-minimum-note.inline-password-minimum-note-after {
	margin: 10px 0;
	float: none;
	display: block;
}

.password-strength-indicator.short {
	background-color: #f1adad;
	border-color: #e35b5b;
	opacity: 1
}

.password-strength-indicator.short + .password-strength-indicator {
	border-color: #e35b5b;
}

.password-strength-indicator.bad {
	background-color: #fbc5a9;
	border-color: #f78b53;
	opacity: 1
}

.password-strength-indicator.bad + .password-strength-indicator {
	border-color: #f78b53;
}

.password-strength-indicator.good {
	background-color: #ffe399;
	border-color: #ffc733;
	opacity: 1
}

.password-strength-indicator.good + .password-strength-indicator {
	border-color: #ffc733;
}

.password-strength-indicator.strong {
	background-color: #c1e1b9;
	border-color: #83c373;
	opacity: 1
}

.confirm-weak-pwd-wrapper .jsm-field-description {
	margin-top: 7px;
}


/* TODO: get this from php options */
.jsm_membership-post-status {
	display: inline-block;
	padding: 2px 10px 0px 10px;
	color: #fff;
	border-radius: 15px;
	text-transform: uppercase;
}

.jsm_membership-post-status.jsm-draft {
	background: #646464; /* TODO: from php JSM_COLOUR__GRAY */;
}

.jsm_membership-post-status.jsm-pending {
	background: #e49600; /* TODO: from php JSM_COLOUR__ORANGE */;
}

.jsm_membership-post-status.jsm-active {
	background: #7FB069; /* TODO: from php JSM_COLOUR__GREEN */;
}

.jsm_membership-post-status.jsm-expired {
	background: #E51C24; /* TODO: from php JSM_COLOUR__RED */
}

.jsm_membership-post-status.jsm-archived {
	background: #e49600; /* TODO: from php JSM_COLOUR__ORANGE */;
}

.jsm_account_tabs {
	margin: 0 0 20px 0;
}

.jsm-field + .jsm_account_tabs {
	margin-top: 25px;
}

.jsm-page-wsa .jsm_account_tabs.ui-widget {
    font-family: 'ProximaNovaCnLtLight', sans-serif; /* TODO: for WSA, do for FoHT */
    font-size: 1em;
}

.jsm-page-foht .jsm_account_tabs.ui-widget {
    font-family: 'Open Sans', sans-serif; /* TODO: for WSA, do for FoHT */
    font-size: 1em;
}

.jsm_account_tabs .ui-tabs-nav li {
	float: left;
}

.jsm_account_tabs  .ui-tabs-nav li:first-child {
    margin-left: 7px !important; /* TODO, remove this (important is only to override a bad WSA style!) */
}

.jsm_account_tabs .ui-state-default, 
.jsm_account_tabs.ui-widget-content .ui-state-default, 
.jsm_account_tabs .ui-widget-header .ui-state-default {
    border: 1px solid #646464;
	border-bottom: 0;
    background: #d8d8d8;
    color: #000;
	padding: 2px 0px;
	margin-right: 2px !important; /* TODO, remove this (important is only to override a bad WSA style!) */
	position: relative;
}

.jsm_account_tabs.ui-widget-content .ui-state-default a {
    color: #000;
	float: none !important;
	padding-left: 7px;
}

.jsm-page-wsa .jsm_account_tabs .ui-state-active,
.jsm-page-wsa .jsm_account_tabs.ui-widget-content .ui-state-active, 
.jsm-page-wsa .jsm_account_tabs .ui-widget-header .ui-state-active,
.jsm-page-wsa .jsm_account_tabs .ui-state-hover,
.jsm-page-wsa .jsm_account_tabs.ui-widget-content .ui-state-hover, 
.jsm-page-wsa .jsm_account_tabs .ui-widget-header .ui-state-hover,
.jsm-page-wsa .jsm_account_tabs .ui-state-defaul.ui-state-hover,
.jsm-page-wsa .jsm_account_tabs.ui-widget-content .ui-state-defaul.ui-state-hover, 
.jsm-page-wsa .jsm_account_tabs .ui-widget-header .ui-state-defaul.ui-state-hover {
    border: 1px solid #7FB069 !important; /* TODO, remove this (important is only to override a bad WSA style!) */
	border-bottom: 0 !important; /* TODO, remove this (important is only to override a bad WSA style!) */
    background: #7FB069 !important; /* TODO, remove this (important is only to override a bad WSA style!) */
    color: #fff;
}

.jsm_account_tabs.ui-widget-content .ui-state-active a {
    color: #fff;
}

.jsm-page-foht .jsm_account_tabs .ui-state-active,
.jsm-page-foht .jsm_account_tabs.ui-widget-content .ui-state-active, 
.jsm-page-foht .jsm_account_tabs .ui-widget-header .ui-state-active,
.jsm-page-foht .jsm_account_tabs .ui-state-hover,
.jsm-page-foht .jsm_account_tabs.ui-widget-content .ui-state-hover, 
.jsm-page-foht .jsm_account_tabs .ui-widget-header .ui-state-hover,
.jsm-page-foht .jsm_account_tabs .ui-state-defaul.ui-state-hover,
.jsm-page-foht .jsm_account_tabs.ui-widget-content .ui-state-defaul.ui-state-hover, 
.jsm-page-foht .jsm_account_tabs .ui-widget-header .ui-state-defaul.ui-state-hover {
    border: 1px solid #7FB069 !important; /* TODO, remove this (important is only to override a bad WSA style!) */
	border-bottom: 0 !important; /* TODO, remove this (important is only to override a bad WSA style!) */
    background: #7FB069 !important; /* TODO, remove this (important is only to override a bad WSA style!) */
    color: #fff;
}

.jsm_account_tabs .ui-tabs-nav .jsm_membership_user_tab .ui-tabs-anchor {
    font-size: 90%;
	padding: .4em .5em .4em .5em;
	text-decoration: none !important;
}

.jsm_account_tabs .ui-tabs-nav .jsm_membership_user_tab.use-jsm-person-tab-numbers .ui-tabs-anchor {
    padding-left: 1.5em;
}

.jsm_account_tabs .jsm-person-tab-number {
    color: #fff;
    background: #646464;
    display: inline-block;
    text-align: center;
    font-weight: 500;
    position: absolute;
    width: 1.25em;
    height: 1.25em;
    left: 4px;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    padding: 1px 0;
	font-size: 80%;
	line-height: 1.1;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
}

.jsm_account_tabs.ui-widget-content .ui-state-active .jsm-person-tab-number {
    color: #7FB069;
    background: #fff;
}

.jsm_account_tabs.ui-widget-content,
.jsm_account_tabs .ui-widget-header {
    background: transparent !important; /* TODO, remove this (important is only to override a bad WSA style!) */
	border: 0 !important; /* TODO, remove this (important is only to override a bad WSA style!) */
}

/* not displaying correctly on FoHT front-end account pages */
.jsm_account_tabs ul.ui-widget-header {
	margin: 0;
	padding: 0;
	list-style: none;
	min-height: 26.9px;
}

.jsm_account_tabs .jsm_membership_user_tabs .ui-widget-content {
    border: 1px solid #7FB069;
	background: #fff;
	border-radius: 4px;
	padding: 10px;
}

.jsm-page-wsa .jsm_account_tabs.ui-widget input, 
.jsm-page-wsa .jsm_account_tabs.ui-widget select, 
.jsm-page-wsa .jsm_account_tabs.ui-widget textarea, 
.jsm-page-wsa .jsm_account_tabs.ui-widget button {
	font-family: 'ProximaNovaCnLtLight', sans-serif; /* TODO: for WSA, do for FoHT */
}

.jsm-page-foht .jsm_account_tabs.ui-widget input, 
.jsm-page-foht .jsm_account_tabs.ui-widget select, 
.jsm-page-foht .jsm_account_tabs.ui-widget textarea, 
.jsm-page-foht .jsm_account_tabs.ui-widget button {
	font-family: 'Open Sans', sans-serif; /* TODO: for WSA, do for FoHT */
}

.jsm-form .ui-datepicker {
	width: auto;
	-webkit-box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.5);
	-moz-box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.5);
	box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.5);
}

.jsm-form .ui-datepicker .ui-datepicker-title select {
	padding: 2px;
	min-width: 70px;
}

.jsm-account-notice {
	float: left;
	width: 100%;
}

.jsm-account-notice:empty {
	margin: 0;
}

.jsm-account-notice p {
	margin: 0;
	display: none;
}

.jsm-account-notice.returned-message p {
	display: block;
	border: 2px solid #000;
	padding: 5px 10px;
	background: #fff;
	float: left;
    clear: left;
	margin-bottom: 10px;
}

.jsm-account-notice p {
	border: 2px solid #000;
	padding: 5px 10px;
	background: #fff;
	float: left;
    clear: left;
	margin-bottom: 10px;
}

.jsm-account-notice.jsm-account-notice-error p {
	border: 2px solid #E51C24; /* TODO: from php JSM_COLOUR__RED */;
    background: #E51C24; /* TODO: from php JSM_COLOUR__RED */;
    color: #fff;
}

.jsm-account-notice.jsm-account-notice-error .fa {
	color: #fff;
}

.jsm-account-notice.jsm-account-notice-success p {
	border: 2px solid #7FB069; /* TODO: from php JSM_COLOUR__GREEN */;
    background: #7FB069; /* TODO: from php JSM_COLOUR__GREEN */;
    color: #fff;
}

.jsm-account-notice.jsm-account-notice-success .fa {
	color: #fff;
}

.jsm-account-notice.jsm-account-notice-success a {
	color: #fff !important;
	text-decoration: underline !important;
}

.jsm-account-notice.jezremyaccount-account-already-exists p {
	margin-bottom: 5px;
}

.jsm-account-notice .fa {
    margin-right: 7px;
}

.jsm-field.mailchimp_user_subscriptions .mailchimp_subscription_counts,
.jsm-field.mailchimp_user_subscriptions .mailchimp_subscriptions {
	width: 100%;
}

.jsm-field.mailchimp_user_subscriptions .mailchimp_subscription_counts p {
	margin-bottom: 7px;
}

.jsm-field.mailchimp_user_subscriptions .mailchimp_subscriptions label {
	width: 100%;
	margin: 0 0 7px 15px;
	width: calc(100% - 8px);
}

.mailchimp_subscriptions label input {
	margin-right: 7px;
}

.jsm_membership_account_page_spinner {
	position: fixed;
	top: 0;
	right: 0;
	left: 0;
	height: 100vh;
	z-index: 1000;
}

.jsm_membership_account_page_spinner .fa {
	font-size: 10em;
	z-index: 10;
	position: absolute;
    top: 50%;
    left: 50%;
    margin-left: -100px;
    margin-top: -100px;
	color: #646464; /* TODO: from php JSM_COLOUR__GRAY */
}

#woocommerce-thankyou-order-received-login {
	float: left;
    width: 100%;
}

.woocommerce-order {
	margin-bottom: 30px;
}

.jsm-fieldset {
	border: 1px solid #646464; /* TODO: from php JSM_COLOUR__GRAY */
	float: left;
    padding: 6px 10px 10px 10px;
    margin: 0px 0 30px 0;
}

.jsm-fieldset legend {
	padding: 0 5px;
    font-weight: bold;
}

.jsm-woocommerce-message-on-account-page {
    background-color: #7FB069; /* TODO: from php JSM_COLOUR__GREEN */
    color: #fff;
    border-top: 3px solid #7FB069;
	padding: 0.5em 0.5em 0.5em 2.5em;
	margin: 0 0 25px 0;
	position: relative;
	overflow: auto;
}

.jsm-woocommerce-message-on-account-page:before {
    content: "\f2c2";
	font-family: FontAwesome;
    display: inline-block;
    position: absolute;
	color: #fff;
	top: 0.5em;
    left: 0.75em;
}

.jsm-woocommerce-message-on-account-page a:not(.button) {
	color: #fff !important;
	text-decoration: underline !important;
}

.jsm-woocommerce-message-on-account-page a.button {
	background: #fff !important;
	color: #7FB069 !important;
	margin: 0 0 5px 5px;
	float: right;
}

.jsm-account-page .jsm-fields {
	margin-bottom: 30px;
}



/*
 * Add to theme stylesheet
 * for display products at top of main shop page
 */
/*
.woocommerce ul.products.featured {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	margin-left: -5px;
	margin-right: -5px;
	width: 100
}

.woocommerce ul.products.featured li.product.featured {
	width: 100%;
	margin: 0 5px 10px 5px !important;
	padding: 10px;
	box-sizing: border-box;
	border: 0;
	background: #7FB069;
	-webkit-box-shadow: none;
	-moz-box-shadow: none;
	box-shadow: none;
}

.woocommerce ul.products.featured li.product.featured a:not(.button) {
	color: #fff !important;
}

.woocommerce ul.products.featured li.product.featured .price {
	color: #fff !important;
}

@media only screen and (min-width: 600px) {
	.woocommerce ul.products.featured li.product.featured {
		width: 50%;
		width: calc(50% - 10px);
	}
}

@media only screen and (min-width: 768px) {
	.woocommerce ul.products.featured li.product.featured {
		width: 33.333%;
		width: calc(33.3333% - 10px);
	}
}

.woocommerce ul.products.featured li.product.featured:nth-child(even) {
	margin-right: 0;
}
*/

/* like the original FoHT mess of classes: .help_tip.help_tip2018.info-notice */
.jsm-wc-product-notice-top {
	margin: 6px 0 23px 0;
}

.jsm-wc-product-notice-inner {
	display: inline-block;
	background: white;
	border: 2px solid #646464; /* TODO: from php JSM_COLOUR__GRAY */;
	color: #000;
    padding: 11px;
}

.notice-color-gray .jsm-wc-product-notice-inner {
	border: 2px solid #646464; /* TODO: from php JSM_COLOUR__GRAY */;
}

.notice-color-green .jsm-wc-product-notice-inner {
	border: 2px solid #7FB069; /* TODO: from php JSM_COLOUR__GREEN */;
}

.notice-color-orange .jsm-wc-product-notice-inner {
	border: 2px solid #e49600; /* TODO: from php JSM_COLOUR__ORANGE */;
}

.notice-color-red .jsm-wc-product-notice-inner {
	border: 2px solid #E51C24; /* TODO: from php JSM_COLOUR__RED */
}

.jsm-wc-product-notice-inner .fa {
    color: #000;
    min-width: 28px;
    float: left;
    margin: 1px 0 0 0;
    font-size: 22px;
}

.notice-color-gray .jsm-wc-product-notice-inner .fa {
    color: #000;
}

.notice-color-green .jsm-wc-product-notice-inner .fa {
    color: #7FB069; /* TODO: from php JSM_COLOUR__GREEN */;
}

.notice-color-orange .jsm-wc-product-notice-inner .fa {
    color: #e49600; /* TODO: from php JSM_COLOUR__ORANGE */;
}

.notice-color-red .jsm-wc-product-notice-inner .fa {
    color: #E51C24; /* TODO: from php JSM_COLOUR__RED */
}

.notice-color-gray .jsm-wc-product-notice-inner p + p .fa,
.notice-color-green .jsm-wc-product-notice-inner p + p .fa,
.notice-color-orange .jsm-wc-product-notice-inner p + p .fa,
.notice-color-red .jsm-wc-product-notice-inner p + p .fa {
    color: #646464; /* TODO: from php JSM_COLOUR__GRAY */
}

.jsm-wc-product-notice-inner p {
    margin-bottom: 3px;
	
	/* if more than one icon might offset each other?! Fix this now: */
	float: left;
    width: 100%;
    clear: left;
}

.jsm-wc-product-notice-inner.jsm-wc-product-notice-inner-more-p-spacing p {
    margin-bottom: 7px;
}

.jsm-wc-product-notice-inner .fa + p, 
.jsm-wc-product-notice-inner .fa + p + p, 
.jsm-wc-product-notice-inner .fa + p + p + p, 
.jsm-wc-product-notice-inner .fa + p + p + p + p {
	margin-left: 30px;
}

.jsm-wc-product-notice-inner p:last-child {
    margin-bottom: 0;
}

.woocommerce ul.order_details li {
	margin-bottom: 5px;
}

.jsm-field-description-jsm_lifetime .wc_price__inc-gst {
	display: none;
}

.jsm-member-discount-like-sale-flash {
    position: absolute;
    top: 0;
    right: 0;
    padding: 4px 8px;
    text-transform: uppercase;
    font-weight: 400;
    background: #646464; /* TODO: from php JSM_COLOUR__GRAY */;
    border: 2px solid #fff;
    border-top: 0;
    border-right: 0;
    color: #fff;
    text-align: center;
    line-height: 1.1;
}

.woocommerce ul.products li.product .jsm-member-discount-like-sale-flash strong {
	display: inline;
}

.jsm-member-discount-like-sale-flash p {
    margin: 0;
}

.woocommerce .product p.price .sale-price.jsm-member-price {
	
}

.woocommerce .product p.price .sale-price.jsm-member-price + .jsm-non-member-price,
.woocommerce .product p.price .sale-price.jsm-member-price + br + .jsm-non-member-price{
	color: #646464; /* TODO: from php JSM_COLOUR__GRAY */;
}

.jsm-cart-checkout-notice {
	margin: 20px 0;
}

.jsm-cart-checkout-notice p {
	display: inline-block;
	padding: 6px 10px;
	background: #646464; /* TODO: from php JSM_COLOUR__GRAY */;
	color: #000;
	margin: 0;
}

.jsm-cart-checkout-notice p.foht-cart-checkout-notice-for-free-guest-membership {
	background: #e49600; /* TODO: from php JSM_COLOUR__ORANGE */;
}

.jsm-cart-checkout-notice p + p {
	margin: 12px 0;
}

.jsm-cart-checkout-notice p:last-child {
	margin-bottom: 0;
}

.jsm-cart-checkout-notice fa {
	color: #000;
}

.woocommerce-thankyou-order-next-steps {
	margin: 20px 0;
}

table.jsm-user-data {
	width: auto;
}

@media screen and (max-width: 767px) {
	.hide-on-mobile {
		display: none !important;
	}
}


.jsm-form.woocommerce div.product form.cart,
.jsm-form .woocommerce div.product form.cart{
	max-width: 500px;
	padding-bottom: 1em;
	border-bottom: 1px solid #646464;
	margin-bottom: 1em;
}

.jsm-form.woocommerce div.product form.cart .button,
.jsm-form .woocommerce div.product form.cart .button {
	float: right;
	margin-top: 30px;
}

.jsm-form.woocommerce div.product form.cart .button + .jsm-field-description,
.jsm-form .woocommerce div.product form.cart .button + .jsm-field-description,
.jsm-form.woocommerce div.product form.cart .button + .jsm-field-description + .jsm-field-description,
.jsm-form .woocommerce div.product form.cart .button + .jsm-field-description + .jsm-field-description{
	float: left;
	width: 100%;
	margin-top: 20px;
	padding-left: 0;
}

.jsm-form.woocommerce div.product form.cart .button + .jsm-field-description + .jsm-field-description,
.jsm-form .woocommerce div.product form.cart .button + .jsm-field-description + .jsm-field-description{
	margin-top: 0px;
}

.mailchimp_subscriptions h4 {
	margin: 8px 0 1px 0;
}

#jsm_membership-mc-subscriptions-ajax-form {
	position: relative;
	max-width: 350px;
}

#jsm_membership-mc-subscriptions-ajax-form button {
	margin: 10px 0;
}

#jsm_membership-mc-subscriptions-ajax-form .spinner {
	display: none;
	
	position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -40px;
    margin-left: -40px;
    font-size: 5em;
}

#jsm_membership-mc-subscriptions-ajax-form.processing .spinner {
	display: block;
}


.jsm-field .jsm_user_dob_table {
	margin: 0;
}

.jsm-field .jsm_user_dob_table th.jsm-like-label {
	float: none;
	clear: none;
	width: 100%;
	margin: 0;
	display: table-cell;
}

.jsm-field .jsm_user_dob_table th.jsm_user_dob_day,
.jsm-field .jsm_user_dob_table th.jsm_user_dob_month,
.jsm-field .jsm_user_dob_table th.jsm_user_dob_year,
.jsm-field .jsm_user_dob_table td.jsm_user_dob_day,
.jsm-field .jsm_user_dob_table td.jsm_user_dob_month,
.jsm-field .jsm_user_dob_table td.jsm_user_dob_year {
	vertical-align: top;
	padding: 0;
}

.jsm-field .jsm_user_dob_table th.jsm_user_dob_day,
.jsm-field .jsm_user_dob_table th.jsm_user_dob_month,
.jsm-field .jsm_user_dob_table th.jsm_user_dob_year {
	font-size: 90%;
	padding-bottom: 4px;
}

.jsm-field .jsm_user_dob_table th.jsm_user_dob_day,
.jsm-field .jsm_user_dob_table td.jsm_user_dob_day {
    width: 20%;
}

.jsm-field .jsm_user_dob_table th.jsm_user_dob_month,
.jsm-field .jsm_user_dob_table td.jsm_user_dob_month {
    width: 45%;
	padding-left: 3% !important;
}

.jsm-field .jsm_user_dob_table th.jsm_user_dob_year,
.jsm-field .jsm_user_dob_table td.jsm_user_dob_year {
    width: 35%;
	padding-left: 3% !important;
}

.jsm-field .jsm_user_dob_table input[type="text"],
.jsm-field .jsm_user_dob_table input[type="number"],
.jsm-field .jsm_user_dob_table select {
	float: none;
	clear: none;
	width: 100%;
	min-width: auto;
}

fieldset.jsm-field {
	margin: 0 0 10px 0;
	border: 0;
	padding: 0;
}

fieldset.jsm-field legend {
	font-family: inherit;
	font-weight: bold;
	font-size: inherit;
	padding: 0;
}

.jsm-field-description.jsm-account-already-exists,
.jsm-field-description.jsm_user_email-must-be-unique {
	font-style: normal;
}

.jsm-field-description.jsm-account-already-exists,
.jsm-field-description.jsm_user_email-must-be-unique {
	display: none !important;
}

.jsm-field-description.jsm-account-already-exists.jsm-display-message,
.jsm-field-description.jsm_user_email-must-be-unique.jsm-display-message {
	display: block !important;
	margin-top: -10px;
}

.jsm-account-already-exists-inner {
	padding: 7px;
	color: #fff;
}

.jsm-field-description.jsm-account-already-exists.jsm-display-message.processing .jsm-account-already-exists-inner,
.jsm-field-description.jsm_user_email-must-be-unique.jsm-display-message.processing .jsm-account-already-exists-inner {
	background: #e49600; /* TODO: from php JSM_COLOUR__ORANGE */
}

.processed.processed-ok .jsm-account-already-exists-inner {
	background: #7FB069; /* TODO: from php JSM_COLOUR__GREEN */
}

.processed.processed-bad .jsm-account-already-exists-inner {
	background: #E51C24; /* TODO: from php JSM_COLOUR__RED */
}

.processed.processed-warning .jsm-account-already-exists-inner {
	background: #e49600; /* TODO: from php JSM_COLOUR__ORANGE */
}

.jsm-account-already-exists-inner p {
	margin-bottom: 5px;
}

.jsm-account-already-exists-inner p:last-child {
	margin-bottom: 0;
}

.jsm-account-already-exists-inner .fa {
	color: #fff;
}

.jsm-account-already-exists-inner a,
.jsm-account-already-exists-inner a:link, 
.jsm-account-already-exists-inner a:visited {
	color: #fff;
	text-decoration: underline;
	font-weight: normal
}

.product .excerpt,
.product .excerpt p {
	font-weight: 400;
}


.woocommerce-notice.woocommerce-thankyou-order-failed {
	padding: 5px 10px;
    background: #E51C24; /* TODO: from php JSM_COLOUR__RED */
    color: white;
    font-weight: bold;
}

#user-has-logged-out {
	position: fixed;
	z-index: 999;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0,0,0,0.8);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -ms-flex-line-pack: center;
        align-content: center;
}

#user-has-logged-out .user-has-logged-out-inside {
	background: #fff;
	padding: 20px;
}

#user-has-logged-out #loginform + p,
#user-has-logged-out .jsm-fields {
	margin-bottom: 0;
}

.user-role ul {
	margin-bottom: 0;
}

.jsm-login-page #breadcrumbs,
.jsm-login-page .breadcrumbs_wrapper {
	display: none;
}

/* just fix it */
@media screen and (min-width: 700px) {
	.jsm-field.jsm_user_dob_fieldset > .jsm-like-label,
	.jsm-field.jsm-display-block.jsm_user_dob_fieldset > .jsm-like-label,
	.jsm-field.jsm_user_dob_fieldset > .jsm-like-input,
	.jsm-field.jsm-display-block.jsm_user_dob_fieldset > .jsm-like-input {
		float: left;
	}
}

.jsm_msg_after_max_num_ppl_on_plan {
    display: block;
    line-height: 1.2;
}

/* The Modal (background) */
.jsm-modal {
    display: none; /* Hidden by default */
    position: fixed; /* Stay in place */
    z-index: 1; /* Sit on top */
    left: 0;
    top: 0;
    padding-top: 100px;
    width: 100%; /* Full width */
    height: 100%; /* Full height */
    overflow: auto; /* Enable scroll if needed */
    background-color: rgb(0,0,0); /* Fallback color */
    background-color: rgba(0,0,0,0.7); /* Black w/ opacity */
}

/* The Close Button */
.jsm-modal-close {
    color: #fff;
    float: right;
    font-size: 28px;
    font-weight: bold;
}

.jsm-modal-close:hover,
.jsm-modal-close:focus {
    color: black;
    text-decoration: none;
    cursor: pointer;
}

/* Modal Header */
.jsm-modal-header {
    padding: 2px 16px;
    background-color: #E51C24;
    color: #fff;
}

/* Modal Header */
.jsm-modal-header h2 {
    clear: none;
}

/* Modal Body */
.jsm-modal-body {
    padding: 16px 16px;
}

.jsm-modal-body > *:last-child {
    margin-bottom: 0;
}

/* Modal Footer */
.jsm-modal-footer {
    padding: 2px 16px;
    background-color: #E51C24;
    color: white;
}

/* Modal Content */
.jsm-modal-content {
    position: relative;
    background-color: #fefefe;
    margin: auto;
    padding: 0;
    border: 1px solid #888;
    width: 80%;
    max-width: 600px;
    box-shadow: 0 4px 8px 0 rgba(0,0,0,0.2),0 6px 20px 0 rgba(0,0,0,0.19);
    animation-name: jsmModalAnimateTop;
    animation-duration: 0.4s
}

.jsm-modal-button,
.jsm-form.woocommerce div.product form.cart .jsm-modal-button {
    float: none;
    margin: 0;
    background-color: #E51C24;
    color: #fff;
}

/* Add Animation */
@keyframes jsmModalAnimateTop {
  from {top: -300px; opacity: 0}
  to {top: 0; opacity: 1}
}

.jsm-field .jsm-radio-container {
    display: flex;
    margin-bottom: 6px;
}

.jsm-field .jsm-radio-container label {
    clear: none;
    width: auto;
}

.jsm-field .jsm-radio-container input[type="radio"] {
    margin-right: 7px;
}

.jsm-break {
    flex-basis: 100%;
    width: 0px !important;
    height: 0px;
    overflow: hidden;
    
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    box-shadow: none !important;
}

.woocommerce a.button.foht-green-btn, 
.woocommerce button.button.foht-green-btn, 
.woocommerce input.button.foht-green-btn {
    color: #fff;
    background-color: #7FB069;
}

.woocommerce a.button.foht-green-btn:hover, 
.woocommerce button.button.foht-green-btn:hover, 
.woocommerce input.button.foht-green-btn:hover {
    color: #fff;
    background-color: #515151;
}

.woocommerce .jsm-wc-product-notice-inner.jsm-wc-product-notice-inner-more-p-spacing p a.button.foht-green-btn, 
.woocommerce .jsm-wc-product-notice-inner.jsm-wc-product-notice-inner-more-p-spacing p button.button.foht-green-btn, 
.woocommerce .jsm-wc-product-notice-inner.jsm-wc-product-notice-inner-more-p-spacing p input.button.foht-green-btn {
    margin-top: 5px;
}

.product .jsm-excerpt-in-product-archives,
.product a .jsm-excerpt-in-product-archives {
    font-weight: 400;
    margin-bottom: 0.5em;
    font-size: .857em;
}
