div.validation-summary-errors {
	margin-bottom: 1rem;
	background: #f04124;
}

	div.validation-summary-errors > ul {
		margin-left: 0rem;
		margin-bottom: 0rem;
		font-size: 0.75rem;
		font-weight: normal;
		font-style: italic;
		color: #fff;
		padding: 0.375rem 0.5625rem 0.5625rem;
	}

.validation-summary-valid {
	display: none;
}

/*Foundation*/
.row {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 0;
    margin-bottom: 0;
    max-width: 62.5rem;
}

.row.reset-password {
    margin-top: 0 !important;
}

.column, .columns {
    position: relative;
    padding-left: 0.9375rem;
    padding-right: 0.9375rem;
    float: left;
}

form {
    padding: 0;
}

fieldset {
    border: 1px solid #ddd;
    padding: 1.25rem;
    margin: 1.125rem 0;
}

fieldset legend {
    font-weight: bold;
    background: #fff;
    padding: 0 0.1875rem;
    margin: 0;
    margin-left: -0.1875rem;
}

.row .row {
    width: auto;
    margin-left: -0.9375rem;
    margin-right: -0.9375rem;
    margin-top: 0;
    margin-bottom: 0;
    max-width: none;
}

.small-12 {
    width: 100%;
}

label {
    font-size: 0.875rem;
    color: #4d4d4d;
    cursor: pointer;
    display: block;
    font-weight: normal;
    line-height: 1.5;
    margin-bottom: 0;
}

input[type="text"], input[type="password"], input[type="date"], input[type="datetime"], input[type="datetime-local"], input[type="month"], input[type="week"], input[type="email"], input[type="number"], input[type="search"], input[type="tel"], input[type="time"], input[type="url"], textarea {
    -webkit-appearance: none;
    -webkit-border-radius: 0px;
    background-color: #fff;
    font-family: inherit;
    border: 1px solid #ccc;
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.1);
    color: rgba(0,0,0,0.75);
    display: block;
    font-size: 0.875rem;
    margin: 0 0 1rem 0;
    padding: 0.5rem;
    height: 2.3125rem;
    width: 100%;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    transition: box-shadow 0.45s,border-color 0.45s ease-in-out;
}

button, .button {
    display: inline-block;
}



/*BMW CUSTOM*/

.login-page {
  background-size: cover;
  background-position: left center;
  background-repeat: no-repeat;
  min-height: 100vh;
}

.login-section {
    height: 89vh;
    position: absolute;
    width: 100%;
    padding: 20px;
    bottom: 0;
    display: flex;
    /* bottom: 0; */
    align-items: center;
}

.login-page .container {
    background: #fff;
    max-width: 550px;
    padding: 35px 25px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
}

.login-page .container.wide-container {
    max-width: 750px;
}


.form-heading h2 {
    font-family: 'BMWGroupLight-Regular';
    font-size: 33px;
    line-height: 36px;
    margin-bottom: 15px;
    text-transform: uppercase;
}

fieldset {
    margin: 20px 0;
}

label {
    font-size: 15px;
    color: #4d4d4d;
    cursor: pointer;
    display: block;
    font-weight: normal;
    line-height: 1.5;
    margin-bottom: 0;
}

.login {
    visibility: visible;
    opacity: 1;
    height: inherit;
}

.login.hidden {
    visibility: collapse;
    opacity: 0;
    height: 0;
}

.row.no-legend fieldset{
    margin: 20px 0 10px 0;
}

.row.no-legend fieldset legend{
    display: none;
}

.row.no-legend form{
    margin: 0 0 10px 0;
}

.row .small-6.columns {
    width: 100%;
}

.small-6.columns button {
    background-color: #1c69d4;
    font-family: 'BMWGroup-Bold';
    min-width: 285px;
    padding: 13px;
    margin: 0;
    font-size: 14px;
    display: inline-block;
    text-align: center;
    color: #FFFFFF;
    text-decoration: none;
    -moz-transition: background-color .25s ease;
    -webkit-transition: background-color .25s ease;
    -o-transition: background-color .25s ease;
    transition: background-color .25s ease;
    border: 0;
    cursor: pointer;
    outline: none;
}

.forgot-password {
    visibility: collapse;
    opacity: 0;
    height: 0;
    display: none;
}

.forgot-password.active {
    visibility: visible;
    opacity: 1;
    height: inherit;
    display: block;
}

.login-links a {
    display: block;
    color: #0067DB;
    font-size: 13px;
    cursor: pointer;
    text-decoration: underline;
}

/*Logout*/

.row.logout fieldset {
    margin: 0;
    padding: 0;
    border: none;
}

.row.logout fieldset legend {
    display: none;    
}

.row.logout button {
    background: transparent;
    margin: 5px 0 0 0;
    padding: 0;
    display: block;
    color: #0067DB;
    font-size: 14px;
    cursor: pointer;
    text-decoration: underline;
    font-family: 'BMWGroupLight-Regular';
    width: auto;
    text-align: left;
    -webkit-transition-property: none;
    -moz-transition-property: none;
    -o-transition-property: none;
    transition-property: none;
    border: 0;
    outline: none;
}

.row.edit-profile .small-6.columns {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.row.edit-profile form {
    width: 48%;
    margin: 0;
}

.row.edit-profile fieldset legend {
    font-family: 'BMWGroup-Bold';
}

.row.edit-profile fieldset {
    margin: 20px 0 0 0;
}

/*Reset Password*/

.login-section.reset-section {height: 100vh; margin-top: 0;}
.row.reset-password fieldset legend {display: none;}

@media all and (max-width: 1200px) {
.login-section {padding: 150px 25px 50px 25px; margin-top: 0;}
}

@media all and (max-width: 1025px) {
.login-page {background-position: center center;}
.login-section {position: relative; height: auto; padding: 100px 25px 50px 25px; margin-top: 0;}
}
    
@media all and (max-width: 768px) {
    .login-page {height: 100%;}
    .login-page .container.wide-container {max-width: 100%;}
    .row.edit-profile form {width: 100%;}
    /*.login-section {position: relative; height: auto; padding: 100px 25px 50px 25px; margin-top: 0;}*/
    .login-section.reset-section {margin-top: 0;}
}

@media all and (max-width: 600px) {
 .small-6.columns button {width: 100%; min-width: inherit;}   
}

/* Landscape */
@media screen and (orientation:landscape) and (max-device-width: 1200px) {
   .login-section {padding: 150px 25px 50px 25px; margin-top: 0; position: relative; height: auto;}  
}

@media all and (max-width: 450px) {
 /*.login-section {padding: 50px 25px;}*/
 .login-page .container {padding: 35px 10px;}
}

.alert-box.success.radius.hidden {
    visibility: collapse;
    height: 0;
    display: none;
    opacity: 1;
}