/* ===========================
   PLENO CRM - Login Page CSS
   =========================== */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap');

:root {
    --navy-600: #1B2B4B;
    --navy-700: #16233D;
    --gray-100: #F3F4F6;
    --gray-200: #E5E7EB;
    --gray-400: #9CA3AF;
    --gray-500: #6B7280;
    --gray-700: #374151;
    --gray-900: #111827;
    --red-50:   #FEF2F2;
    --red-200:  #FECACA;
    --red-600:  #DC2626;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
    font-family: 'Plus Jakarta Sans', sans-serif;
    background: #F9FAFB;
    min-height: 100vh;
    display: flex;
    -webkit-font-smoothing: antialiased;
}

/* --- Layout --- */
.login-page {
    display: flex;
    width: 100%;
    min-height: 100vh;
}

/* --- Left Panel (Marketing) --- */
.login-left {
    flex: 1;
    display: flex;
    align-items: center;
    padding: 60px 80px;
    background: #F9FAFB;
}

.login-left-content { max-width: 500px; }

.login-headline {
    font-size: 38px;
    font-weight: 800;
    color: var(--navy-600);
    line-height: 1.2;
    letter-spacing: -0.5px;
    margin-bottom: 24px;
    text-transform: uppercase;
}

.login-subtext {
    font-size: 15px;
    color: var(--gray-400);
    line-height: 1.7;
    font-weight: 400;
}

/* --- Right Panel (Form) --- */
.login-right {
    width: 520px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px;
    background: #F9FAFB;
    flex-shrink: 0;
}

.login-card {
    width: 100%;
    max-width: 440px;
    background: white;
    border-radius: 16px;
    padding: 48px 40px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.08), 0 8px 32px rgba(0,0,0,0.06);
}

/* --- Logo --- */
.login-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin-bottom: 40px;
}

.login-logo-text {
    font-size: 22px;
    font-weight: 800;
    color: var(--navy-600);
    letter-spacing: -0.5px;
}

/* --- Error --- */
.login-error {
    background: var(--red-50);
    border: 1px solid var(--red-200);
    color: var(--red-600);
    font-size: 13px;
    border-radius: 8px;
    padding: 12px 16px;
    margin-bottom: 20px;
}

/* --- Form --- */
.login-form { display: flex; flex-direction: column; gap: 0; }

.form-group { margin-bottom: 20px; }
.form-group-last { margin-bottom: 0; }

.form-label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--gray-700);
    margin-bottom: 8px;
}

.form-input {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid var(--gray-200);
    border-radius: 8px;
    font-size: 14px;
    color: var(--gray-700);
    background: white;
    outline: none;
    font-family: inherit;
    transition: border-color 0.2s;
}

.form-input:focus { border-color: var(--navy-600); }
.form-input::placeholder { color: var(--gray-400); }

/* --- Password Field --- */
.password-wrapper {
    position: relative;
}

.password-wrapper .form-input { padding-right: 44px; }

.password-toggle {
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    color: var(--gray-400);
    padding: 0;
    display: flex;
    align-items: center;
    transition: color 0.15s;
}

.password-toggle:hover { color: var(--gray-600); }

.password-toggle svg { width: 18px; height: 18px; }

/* --- Forgot Password --- */
.forgot-row {
    text-align: right;
    margin-bottom: 32px;
    margin-top: -8px;
}

.forgot-link {
    font-size: 13px;
    color: var(--gray-500);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.15s;
}

.forgot-link:hover { color: var(--navy-600); }

/* --- Submit Button --- */
.btn-login {
    width: 100%;
    padding: 14px;
    background: var(--navy-600);
    color: white;
    border: none;
    border-radius: 8px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s;
    font-family: inherit;
}

.btn-login:hover { background: var(--navy-700); }

/* --- Responsive --- */
@media (max-width: 900px) {
    .login-left { display: none; }
    .login-right { width: 100%; }
}

@media (max-width: 480px) {
    .login-right { padding: 24px 16px; }
    .login-card { padding: 32px 24px; }
    .login-headline { font-size: 28px; }
}
