/* auth.css — Styles for login and password change pages */

/* --- From login.html --- */
* { box-sizing: border-box; }
        body {
            min-height: 100vh;
            margin: 0;
            background: linear-gradient(135deg, #2c3e50 0%, #3a5068 60%, #1b4f72 100%);
            display: flex;
            align-items: center;
            justify-content: center;
            font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
        }
        .login-card {
            width: 100%;
            max-width: 400px;
            margin: 1rem;
        }
        .login-header {
            text-align: center;
            margin-bottom: 2rem;
        }
        .login-logo {
            width: 64px;
            height: 64px;
            border-radius: 16px;
            background: rgba(255,255,255,.12);
            display: inline-flex;
            align-items: center;
            justify-content: center;
            margin-bottom: 1.25rem;
        }
        .login-header h1 {
            font-size: 1.35rem;
            font-weight: 700;
            color: #fff;
            margin: 0 0 .35rem;
        }
        .login-header p {
            font-size: .82rem;
            color: rgba(255,255,255,.5);
            margin: 0;
        }
        .login-panel {
            background: #fff;
            border-radius: 16px;
            box-shadow: 0 12px 40px rgba(0,0,0,.2);
            overflow: hidden;
        }
        .login-body {
            padding: 2rem 2rem 1.5rem;
        }
        .login-body .form-label {
            font-size: .82rem;
            font-weight: 600;
            color: #495057;
            margin-bottom: .3rem;
        }
        .login-body .form-control {
            border-radius: 10px;
            padding: .6rem .85rem;
            font-size: .9rem;
            border-color: #dee2e6;
            transition: border-color .15s, box-shadow .15s;
        }
        .login-body .form-control:focus {
            border-color: #2c3e50;
            box-shadow: 0 0 0 3px rgba(44,62,80,.12);
        }
        .btn-login {
            width: 100%;
            padding: .6rem;
            border-radius: 10px;
            font-size: .9rem;
            font-weight: 600;
            background: linear-gradient(135deg, #2c3e50, #3a5068);
            border: none;
            color: #fff;
            transition: opacity .15s, transform .1s;
            cursor: pointer;
        }
        .btn-login:hover { opacity: .9; }
        .btn-login:active { transform: scale(.98); }
        .login-footer {
            background: #f8f9fa;
            border-top: 1px solid #f0f0f0;
            padding: .75rem 2rem;
            text-align: center;
        }
        .login-footer p {
            font-size: .72rem;
            color: #adb5bd;
            margin: 0;
        }
        .alert {
            border-radius: 10px;
            font-size: .85rem;
            margin-bottom: 1rem;
        }

.pwd-panel {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 2px 12px rgba(0,0,0,.08);
    overflow: hidden;
}
.pwd-header {
    background: linear-gradient(135deg, #2c3e50 0%, #3a5068 100%);
    color: #fff;
    padding: 1.25rem 1.5rem;
    display: flex;
    align-items: center;
    gap: .75rem;
}
.pwd-header-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: rgba(255,255,255,.15);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.pwd-header h1 {
    font-size: 1.05rem;
    font-weight: 600;
    margin: 0;
}
.pwd-header p {
    font-size: .8rem;
    color: rgba(255,255,255,.6);
    margin: .15rem 0 0;
}
.pwd-body {
    padding: 1.5rem;
}
.pwd-body .form-label {
    font-size: .82rem;
    font-weight: 600;
    color: #495057;
    margin-bottom: .3rem;
}
.pwd-body .form-control {
    border-radius: 8px;
    font-size: .875rem;
    border-color: #dee2e6;
}
.pwd-body .form-control:focus {
    border-color: #2c3e50;
    box-shadow: 0 0 0 2px rgba(44,62,80,.12);
}
.pwd-body .btn {
    border-radius: 8px;
    font-size: .85rem;
    padding: .4rem 1.2rem;
}
.pwd-hint {
    font-size: .75rem;
    color: #adb5bd;
    margin-top: .25rem;
}

input[required]:not([readonly]):not([disabled]):invalid,
select[required]:not([readonly]):not([disabled]):invalid,
textarea[required]:not([readonly]):not([disabled]):invalid,
.form-control[required]:not([readonly]):not([disabled]):invalid,
.form-select[required]:not([readonly]):not([disabled]):invalid {
    border-color: #dc3545 !important;
}

input[required]:not([readonly]):not([disabled]):invalid:focus,
select[required]:not([readonly]):not([disabled]):invalid:focus,
textarea[required]:not([readonly]):not([disabled]):invalid:focus,
.form-control[required]:not([readonly]):not([disabled]):invalid:focus,
.form-select[required]:not([readonly]):not([disabled]):invalid:focus {
    border-color: #dc3545 !important;
    box-shadow: 0 0 0 .18rem rgba(220, 53, 69, .16) !important;
}
