@charset "utf-8";
/* Moblico Portal Retheme — Phase 7: Login Page */

/* ===== Page Scaffold ===== */

body, #body-wrapper {
    background: linear-gradient(145deg, #012D47 0%, #023C5F 50%, #034F7A 100%) !important;
    min-height: 100vh;
    margin: 0;
    padding: 0;
}

#outer-wrapper {
    background: transparent !important;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden;
}

/* Decorative corner glow — top-right (orange) */
#outer-wrapper::before {
    content: '';
    position: absolute;
    top: -120px;
    right: -120px;
    width: 360px;
    height: 360px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(248,174,40,0.07) 0%, transparent 70%);
    pointer-events: none;
    z-index: 0;
}

/* Decorative corner glow — bottom-left (blue) */
#outer-wrapper::after {
    content: '';
    position: absolute;
    bottom: -80px;
    left: -80px;
    width: 280px;
    height: 280px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(57,162,218,0.08) 0%, transparent 70%);
    pointer-events: none;
    z-index: 0;
}

#outer-content-wrapper,
.centeredcontent {
    background: transparent !important;
}

/* Hide the moblico.com nav/logo header bar — logo lives inside the card */
header#header-wrapper {
    display: none;
}

/* Center the card + footer vertically and horizontally as a group */
#outer-content-wrapper {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 48px 20px;
    position: relative;
    z-index: 1;
}

/* White login card */
#content-wrapper {
    background: #ffffff !important;
    max-width: 420px !important;
    width: 100% !important;
    border-radius: var(--radius-xl, 14px) !important;
    box-shadow: 0 8px 40px rgba(2,60,95,0.22), 0 2px 8px rgba(2,60,95,0.10) !important;
    padding: 40px 40px 36px !important;
    box-sizing: border-box !important;
    position: relative;
    z-index: 1;
}

/* Hide the old moblico.com footer entirely on the login page */
footer#footer-wrapper {
    display: none !important;
}

/* Custom login page footer — moved into #outer-wrapper flex column via JS */
#login-page-footer {
    text-align: center;
    padding: 0 20px 28px;
    font-size: 11px;
    font-family: 'Fira Sans', sans-serif;
    color: rgba(255,255,255,0.4);
    position: relative;
    z-index: 1;
}

#login-page-footer .login-footer-sep {
    color: rgba(255,255,255,0.2);
    margin: 0 10px;
}

#login-page-footer a,
#login-page-footer a:visited {
    color: rgba(255,255,255,0.5);
    text-decoration: none;
}

#login-page-footer a:hover {
    color: rgba(255,255,255,0.8);
}

/* ===== Logo Area ===== */

.login-logo-compound {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 0;
}

.login-logo-img {
    max-width: 240px;
    height: auto;
    display: block;
    margin-bottom: 8px;
}

.login-divider {
    height: 1px;
    width: 48px;
    background: #DDE3E8;
    border: none;
    margin: 0 auto 28px;
    display: block;
}

/* ===== Card Title ===== */

#loginFormWrapper h2.subheading2,
#forgotPasswordWrapper h2.subheading2 {
    font-family: var(--font-heading, 'Poppins', sans-serif) !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    font-style: normal !important;
    color: #023C5F;
    text-align: center;
    margin: 0 0 24px !important;
    line-height: 1.3;
}

/* Management / Developer title stays red */
#loginFormWrapper h2.subheading2.mgmt {
    color: #B70000;
}

/* ===== Alert Banner ===== */

.login-alert {
    border-radius: 8px;
    padding: 11px 14px;
    margin-bottom: 20px;
    display: flex;
    align-items: flex-start;
    gap: 9px;
    box-sizing: border-box;
}

.login-alert--error {
    background: #FEE8E6;
    border: 1px solid #F5C0BC;
}

.login-alert--success {
    background: #EAF6E9;
    border: 1px solid #B6DEB3;
}

.login-alert-icon {
    flex-shrink: 0;
    margin-top: 1px;
    font-size: 14px;
    line-height: 1.5;
}

.login-alert--error .login-alert-icon,
.login-alert--error .login-alert-text,
.login-alert--error .login-alert-text p,
.login-alert--error .login-alert-text a {
    color: #D93025 !important;
}

.login-alert--success .login-alert-icon,
.login-alert--success .login-alert-text {
    color: #2A7A26;
}

.login-alert-text {
    font-size: 12px;
    font-family: 'Fira Sans', sans-serif;
    line-height: 1.5;
}

.login-alert-text p {
    margin: 0 0 4px;
    font-size: 12px;
}

.login-alert-text p:last-child {
    margin-bottom: 0;
}

/* ===== Form Layout ===== */

/* Stack label above input */
#loginFormWrapper .labelhorizwrapper {
    display: flex !important;
    flex-direction: column !important;
    margin-bottom: 16px;
    width: 100% !important;
}

/* Field labels — must use !important to beat moblico2014.css which sets display:none */
#loginFormWrapper .labelhorizwrapper label,
#forgotPasswordWrapper .labelhorizwrapper label {
    display: block !important;
    font-family: var(--font-heading, 'Poppins', sans-serif) !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
    color: var(--color-body-text, #45515C) !important;
    margin-bottom: 5px !important;
    text-align: left !important;
    float: none !important;
    width: auto !important;
    position: static !important;
}

/* Hide spacer &nbsp; labels before submit button */
#loginFormWrapper .labelhorizwrapper label.marginright10,
#forgotPasswordWrapper .labelhorizwrapper label.marginright10 {
    display: none !important;
}

/* Input icon wrapper */
.input-icon-wrap {
    position: relative;
}

.input-icon {
    position: absolute;
    left: 11px;
    top: 50%;
    transform: translateY(-50%);
    color: #A0AEB8;
    font-size: 14px;
    pointer-events: none;
    z-index: 1;
    line-height: 1;
}

/* Base input style */
#loginFormWrapper .medinput,
#loginFormWrapper input.medinput {
    box-sizing: border-box;
    height: 42px;
    border-radius: 7px;
    font-family: var(--font-body, 'Fira Sans', sans-serif);
    font-size: 14px;
    color: var(--color-near-black, #2E2925);
    background: #ffffff;
    outline: none;
    float: none;
    margin: 0;
}

/* Plain label + input (no icon wrapper) */
#loginFormWrapper #mainform .labelhorizwrapper label + input,
#forgotPasswordWrapper label + input[type=text] {
    width: 100% !important;
    padding: 0 12px !important;
    height: 42px !important;
    border: 1.5px solid #DDE3E8 !important;
    box-sizing: border-box !important;
    border-radius: 7px !important;
}

/* Inputs inside icon wrapper */
#loginFormWrapper .input-icon-wrap input,
#forgotPasswordWrapper .input-icon-wrap input {
    width: 100% !important;
    padding: 0 12px 0 36px !important;
    height: 42px !important;
    border: 1.5px solid #DDE3E8 !important;
    box-sizing: border-box !important;
    border-radius: 7px !important;
    font-family: var(--font-body, 'Fira Sans', sans-serif) !important;
    font-size: 14px !important;
    color: var(--color-near-black, #2E2925) !important;
    background: #ffffff !important;
    outline: none;
}

/* Focus states */
#loginFormWrapper .medinput:focus,
#loginFormWrapper #mainform .labelhorizwrapper label + input:focus,
#loginFormWrapper .input-icon-wrap input:focus,
#forgotPasswordWrapper .input-icon-wrap input:focus {
    border-color: #006AA9 !important;
    box-shadow: 0 0 0 3px rgba(0,106,169,0.12) !important;
}

/* Error state — password field */
.login-field-error,
#loginFormWrapper .input-icon-wrap input.login-field-error {
    border-color: #D93025 !important;
    background: #FFF5F5 !important;
    box-shadow: 0 0 0 3px rgba(217,48,37,0.08) !important;
}

.input-icon--error {
    color: #D93025 !important;
}

.login-field-error-msg {
    display: flex;
    align-items: center;
    gap: 5px;
    margin-top: 5px;
}

.login-field-error-icon {
    color: #D93025;
    font-size: 12px;
}

.login-field-error-text {
    font-size: 11px;
    color: #D93025;
    font-family: 'Fira Sans', sans-serif;
}

/* Reset success back button wrapper */
.login-reset-back-wrap {
    padding-top: 12px;
    width: 100%;
    box-sizing: border-box;
}

/* ===== Remember / Forgot Row ===== */

.login-remember-row {
    display: flex !important;
    flex-direction: row !important;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 22px;
    margin-top: -4px;
    width: 100%;
    box-sizing: border-box;
}

.login-remember-label {
    display: flex;
    align-items: center;
    gap: 7px;
    cursor: pointer;
    margin: 0;
    padding: 0;
}

.login-remember-label input[type="checkbox"] {
    width: 16px;
    height: 16px;
    border-radius: 4px;
    border: 2px solid #DDE3E8;
    accent-color: #006AA9;
    cursor: pointer;
    flex-shrink: 0;
    margin: 0;
    padding: 0;
}

.login-remember-label span {
    font-size: 12px;
    color: #45515C;
    font-family: 'Fira Sans', sans-serif;
}

a.login-forgot-link,
a.login-forgot-link:visited {
    font-family: 'Fira Sans', sans-serif;
    font-size: 12px;
    font-weight: 500;
    color: #006AA9 !important;
    text-decoration: none;
    border-bottom: 1px solid #006AA9;
    padding-bottom: 1px;
    cursor: pointer;
}

a.login-forgot-link:hover {
    color: #004f80 !important;
    border-bottom-color: #004f80;
    text-decoration: none;
}

/* ===== Submit Button Container ===== */

#loginFormWrapper .labelhorizwrapper .floatleft {
    width: 100% !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

#loginFormWrapper .paddingtop10 {
    padding-top: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* Sign In button */
#loginFormWrapper a.saveformbtn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    height: 44px !important;
    background: var(--color-orange, #F8AE28) !important;
    color: var(--color-near-black, #2E2925) !important;
    font-family: var(--font-heading, 'Poppins', sans-serif) !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    text-decoration: none !important;
    border-radius: var(--radius-lg, 8px) !important;
    cursor: pointer;
    transition: background 0.15s;
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 0 !important;
    letter-spacing: 0.2px !important;
    box-shadow: 0 2px 8px rgba(248,174,40,0.35) !important;
}

#loginFormWrapper a.saveformbtn:hover {
    background: #e09d22 !important;
}

/* Hide old forgotpanel (replaced by login-remember-row) */
#loginFormWrapper .paddingtop5.forgotpanel {
    display: none !important;
}

/* Error messages (legacy .error class — still style in case) */
#loginFormWrapper .error {
    color: #D93025 !important;
    font-size: 12px;
    font-family: 'Fira Sans', sans-serif;
    margin-bottom: 8px;
}

/* System messages */
#systemmsg, .systemmsg {
    font-family: var(--font-body, 'Fira Sans', sans-serif);
    font-size: 13px;
}

/* Forgot password success message — style as green alert banner */
#forgotPasswordWrapper .systemmsg {
    background: #EAF6E9 !important;
    border: 1px solid #B6DEB3 !important;
    border-radius: 8px !important;
    padding: 11px 14px !important;
    margin-bottom: 20px !important;
    color: #2A7A26 !important;
    font-size: 12px !important;
    font-family: 'Fira Sans', sans-serif !important;
    line-height: 1.5 !important;
    width: auto !important;
    box-sizing: border-box !important;
}

/* Forgot form description text */
.login-forgot-desc {
    font-size: 13px;
    color: #45515C;
    font-family: 'Fira Sans', sans-serif;
    line-height: 1.6;
    text-align: center;
    margin: 0 0 20px;
}

/* Back to login link below forgot form */
a.login-back-link,
a.login-back-link:visited {
    display: block;
    text-align: center;
    margin-top: 16px;
    font-size: 12px;
    font-weight: 500;
    color: #006AA9 !important;
    font-family: 'Fira Sans', sans-serif;
    text-decoration: none;
    border-bottom: 1px solid #006AA9;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 1px;
    cursor: pointer;
}

a.login-back-link:hover {
    color: #004f80 !important;
    border-bottom-color: #004f80;
}

/* ===== Forgot Password Panel ===== */

#forgotPasswordWrapper {
    display: none;
}

#forgotPasswordWrapper .labelhorizwrapper {
    display: flex !important;
    flex-direction: column !important;
    margin-bottom: 16px;
    width: 100% !important;
}

#forgotPasswordWrapper .labelhorizwrapper label {
    font-family: var(--font-heading, 'Poppins', sans-serif);
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--color-body-text, #45515C);
    margin-bottom: 5px;
    float: none !important;
    width: auto !important;
}

/* Hide spacer label in forgot form button row */
#forgotPasswordWrapper .labelhorizwrapper label.marginright10 {
    display: none !important;
}

#forgotPasswordWrapper .labelhorizwrapper .floatleft {
    width: 100% !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

#forgotPasswordWrapper .paddingtop10 {
    padding-top: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* Send Reset Instructions — full-width orange button */
#forgotPasswordWrapper .saveformbtn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    height: 44px !important;
    background: var(--color-orange, #F8AE28) !important;
    color: var(--color-near-black, #2E2925) !important;
    font-family: var(--font-heading, 'Poppins', sans-serif) !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    text-decoration: none !important;
    border-radius: var(--radius-lg, 8px) !important;
    cursor: pointer;
    padding: 0 !important;
    box-shadow: 0 2px 8px rgba(248,174,40,0.35) !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    transition: background 0.15s;
    letter-spacing: 0.2px !important;
}

#forgotPasswordWrapper .saveformbtn:hover {
    background: #e09d22 !important;
}
