.container {
	height: 100%;
}

.content-landing {
	background-color: #fff;
	border-radius: 10px;
	padding: 30px;
	margin-bottom: 30px
}

.landing-head {
	margin-bottom: 5px;
}

.cAlign {
	color: #eee;
}

h1 {
	margin-top: 15px;
	font-size: 48px;
}

#signin a {
	padding: 0px;
}

.outer {
    height: 90%;
}


.outer {
    display: table;
    position: absolute;
    height: 100%;
}

.middle {
    display: table-cell;
    vertical-align: middle;
}

.registerconfirm, #billing_wrapper, .register, .register-error, #tos {
	display: none;
}

#register-btn {
	margin-left: 5px;
}

@media screen and (min-width: 1200px) {
	.col-md-8 {
		width: 666px;
	}
} /* stops sign-in error from stretching div */

@media screen and (max-width: 992px) {
	.col-md-8 {
		width: 500px;
	}
}

@media screen and (max-width: 768px) {
	h1 {
		float: left;
	}
}

@media screen and (max-width: 480px) {
	.col-md-8 {
		width: 400px;
	}
}

.question {
	margin-top: 10px;
	margin-bottom: 10px;
}
.alert {
	margin-bottom: 0px;
}

.landingalert {
	margin-top: 15px;
}

.landingalert .alert {
	padding: 14px 18px;
	border-radius: 8px;
	font-size: 14px;
	line-height: 1.5;
	border: 1px solid;
}

.landingalert .alertStrip {
	border-radius: 8px;
	text-align: left;
	padding: 14px 18px;
}

.landingalert .alert-success {
	color: #166534;
	background-color: #f0fdf4;
	border-color: #bbf7d0;
}

.landingalert .alert-danger {
	color: #991b1b;
	background-color: #fef2f2;
	border-color: #fecaca;
}

.landingalert .alert-warning {
	color: #92400e;
	background-color: #fffbeb;
	border-color: #fde68a;
}

.landingalert .alert-info {
	color: #1e40af;
	background-color: #eff6ff;
	border-color: #bfdbfe;
}
h1 {
	text-decoration: underline;
}
h3 {
	font-style: italic;
	color: #00a8c6;
}
.bold {
	font-weight: bold;
}

#credit_table td:nth-child(2) {
	text-align: left;
	border-left: 0;
}

.credit_hide {
	display: none;
}

#checkbox_well {
	margin-top: 30px;
}

#agreement_checkbox {
	margin-left: 5px;
}

#credit_table {
	width: 100%;
	margin-bottom: 23px;
}

#credit_table td {
	border: 1px solid #000;
}

#tos-box {
	overflow-y: scroll;
	width: 100%;
	border: 1px solid #00a8c6;
	margin-bottom: 5px;
	height: 500px;
}

#agree-agreement {
	margin-top: 15px;
	margin-bottom: 15px;
}

#signature_table {
	width: 80%;
}

#register-back {
	margin-right: 5px;
}

@media screen and (max-width: 480px) {
	.landing_fix {
		display: none;
	}
}
@media screen and (max-width: 480px) {
	body {
		background: none !important;
	}
}
@media screen and (max-width: 480px) {
	.content-landing {
		padding:5px !important;
	}
}
@media only screen and (max-device-width: 1170px) {
	.content-landing {
		padding:190px !important;
	}
	#signin-button {
		height: 50px;
		width: 100%;
		font-size: 16px;
	}
    .loginBrandImage{
        display: none;
    }
	#nimbus_logo_mobile {
		display: block !important;
	}
	#nimbus_logo_mobile_left{
		width: 140px !important;
		height: 130px;
		margin-left: 68px;
	}
	.container .copyrightFooter {
		margin-left: 0px !important;
	}
}
@media only screen and (max-device-width: 768px) {
	.content-landing {
		padding-left: 10px !important;
	}
	#nimbus_logo_mobile_left {
		width: 110px !important;
		height: 95px;
		margin-left: 0px;
	}
}

/* =============================================
   LOGIN FORM STYLES (Right side only)
   ============================================= */

/* Override flex ratio - left image larger, right form smaller */
.flex-container .loginBrandImage {
	flex: 2.5;
}

.flex-container .login-form {
	flex: 1;
}

/* Login form container */
.login-form {
	display: flex;
	flex-direction: column;
	height: 100vh;
	overflow-y: auto;
}

.login-form #wrapper {
	display: flex;
	flex-direction: column;
	flex: 1;
	height: 100%;
}

.login-form .content-landing {
	display: flex;
	flex-direction: column;
	flex: 1;
	height: 100%;
}

/* Signin container */
#signin {
	display: flex;
	flex-direction: column;
	flex: 1;
}

#signin form {
	display: flex;
	flex-direction: column;
	flex: 1;
}

/* Auth section - flex container to push bottom to bottom */
.login-auth-section {
	display: flex;
	flex-direction: column;
	flex: 1;
}

/* Bottom area - pushed to bottom */
.login-bottom-area {
	margin-top: auto;
}

/* Title */
.login-title {
	font-size: 28px;
	font-weight: 600;
	color: #1a1a1a;
	margin-bottom: 25px;
	text-decoration: none !important;
	display: block;
}

/* Form groups */
.login-form-group {
	margin-bottom: 20px;
}

.login-label {
	display: block;
	font-size: 14px;
	font-weight: 500;
	color: #1a1a1a;
	margin-bottom: 8px;
}

/* Input fields */
.login-input {
	width: 100% !important;
	padding: 15px 18px;
	font-size: 15px;
	border: 1px solid #D7DAE0 !important;
	border-radius: 12px !important;
	background-color: #fff;
	transition: border-color 0.2s ease;
	box-sizing: border-box;
	height: 52px;
}

.login-input:focus {
	outline: none;
	border-color: #999;
}

.login-input::placeholder {
	color: #999;
}

/* Disable autocomplete styling */
.login-input:-webkit-autofill,
.login-input:-webkit-autofill:hover,
.login-input:-webkit-autofill:focus {
	-webkit-box-shadow: 0 0 0px 1000px white inset;
	box-shadow: 0 0 0px 1000px white inset;
	-webkit-text-fill-color: #333;
	border-radius: 6px;
}

/* Password input wrapper with forgot link inside */
.password-input-wrapper {
	position: relative;
}

.password-input-wrapper .login-input {
	padding-right: 120px;
}

.password-input-wrapper .forgot-password-link {
	position: absolute;
	right: 15px;
	top: 50%;
	transform: translateY(-50%);
	z-index: 1;
}

.forgot-password-link {
	font-size: 13px;
	color: #666;
	text-decoration: none;
}

.forgot-password-link:hover {
	color: #DC192F;
	text-decoration: underline;
}

/* Checkbox styles */
.login-checkbox-label {
	display: flex;
	align-items: flex-start;
	cursor: pointer;
	font-weight: 400;
	position: relative;
}

.login-checkbox {
	width: 16px;
	height: 16px;
	margin-right: 8px !important;
	margin-top: 2px !important;
	cursor: pointer;
	flex-shrink: 0;
}

.login-checkbox-text {
	font-size: 14px;
	color: #333;
}

/* Tooltip fix for login page */
#rememberme-group {
	position: relative;
}

#rememberme-group .tooltip {
	position: absolute !important;
}

#rememberme-group .tooltip-inner {
	max-width: 100%;
	padding: 10px 14px;
	border-radius: 6px;
	background-color: #1a1a1a;
}

#rememberme-group .tooltip-arrow {
	display: none;
}

/* Terms text */
.login-terms-text {
	font-size: 13px;
	color: #333;
	line-height: 1.5;
}

.login-terms-link {
	color: #DC192F !important;
	text-decoration: none;
}

.login-terms-link:hover {
	text-decoration: underline;
}

/* Login button */
.login-button-container {
	margin-top: 20px;
}

.btn-login-new {
	width: 100%;
	padding: 16px;
	font-size: 16px;
	font-weight: 500;
	color: #fff;
	background-color: #2D3748;
	border: none;
	border-radius: 8px;
	cursor: pointer;
	transition: background-color 0.2s ease;
}

.btn-login-new:hover {
	background-color: #1A202C;
}

.btn-login-new:focus {
	outline: none;
	box-shadow: 0 0 0 3px rgba(45, 55, 72, 0.3);
}

/* Copyright text */
.login-copyright {
	text-align: left;
	font-size: 12px;
	color: #999;
	margin-top: 20px;
	margin-bottom: 0;
}

/* Hide footer on login page */
.login-footer-hidden {
	display: none;
}

/* =============================================
   RECOVER PASSWORD STYLES
   ============================================= */

.recover {
	display: none;
	flex-direction: column;
	flex: 1;
}

.recover-success {
	display: flex;
	flex-direction: column;
	flex: 1;
}

.recover form {
	display: flex;
	flex-direction: column;
	flex: 1;
}

.recover fieldset {
	margin-bottom: 20px;
}

.recover-subtitle {
	font-size: 14px;
	color: #666;
	margin-bottom: 20px;
}

.recover-error {
	font-size: 14px;
	color: #DC192F;
	background-color: #FFF5F5;
	border: 1px solid #FCCACA;
	border-radius: 6px;
	padding: 10px 14px;
	margin-bottom: 16px;
}

.recover-buttons {
	display: flex;
	gap: 12px;
}

.btn-cancel-recover {
	width: 25%;
	padding: 10px 16px;
	font-size: 16px;
	font-weight: 500;
	color: #2D3748;
	background-color: #fff;
	border: 1px solid #D7DAE0;
	border-radius: 8px;
	cursor: pointer;
	transition: all 0.2s ease;
}

.recover-buttons .btn-login-new {
	padding: 10px 16px;
}

.btn-cancel-recover:hover {
	background-color: #f5f5f5;
	border-color: #999;
}
